sql怎么连接两张表

图片描述
图片描述
图片描述
图片描述

把表一表二以表三为主表合成一张表,没有数据重复,表一表二相互互补,null值转为0,
除了用union,其他的大神指教

阅读 3.3k
1 个回答

我随便写了几条数据,对逻辑没有影响

;with a1([name],徐州)AS(
    SELECT N'旧电器',1 UNION
    SELECT N'农贸市场',1
),a2([name],江阴) AS(
    SELECT N'餐品',1 UNION
    SELECT N'成本油',2 UNION
    SELECT N'酒类',5
),a3([name])AS(
    SELECT N'旧电器' UNION
    SELECT N'农贸市场' UNION
    SELECT N'餐品' UNION
    SELECT N'成本油' UNION
    SELECT N'酒类' UNION
    SELECT N'典当' UNION
    SELECT N'对外劳务' UNION
    SELECT N'aaaa' 
)

SELECT a3.[name],ISNULL(xz.徐州,0) AS 徐州, ISNULL(jy.江阴,0) AS 江阴 FROM a3
OUTER APPLY (
    SELECT a1.徐州 FROM a1 WHERE a1.[name]=a3.[name]
) xz
OUTER APPLY (
    SELECT a2.江阴 FROM a2 WHERE a2.[name]=a3.[name]
) jy

name 徐州 江阴
---- ----------- -----------
aaaa 0 0
典当 0 0
农贸市场 1 0
对外劳务 0 0
成本油 0 2
旧电器 1 0
酒类 0 5
餐品 0 1

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进