;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