CREATE TABLE t(Id int, typee nvarchar(50), jsonStr nvarchar(max));
INSERT INTO t(Id, typee, jsonStr) VALUES
(3786, 'APV', '{"1":1,"3":3,"4":24,"5":95}'),
(3786, 'VN', '{"1":3,"5":25}');
-- Expected result
-- {"APV": {"1":1,"3":3,"4":24,"5":95}, "VN":{"1":3,"5":25} }
SELECT Id,(
SELECT CASE WHEN typee = 'VN' THEN jsonStr END AS [VN]
, CASE WHEN typee = 'VO' THEN jsonStr END AS [VO]
, CASE WHEN typee = 'APV' THEN jsonStr END AS [APV]
FROM t AS x
WHERE x.Id = t.Id
FOR JSON AUTO, WITHOUT_ARRAY_WRAPPER
) AS TEST1
FROM t
GROUP BY Id
我想得到如下输出:
{
"APV": {
"1": 1,
"3": 3,
"4": 24,
"5": 95
},
"VN": {
"1": 3,
"5": 25
}
}
最佳答案
FOR JSON
会将字符串视为字符串,即使它表示有效的 JSON。您需要使用 JSON_QUERY
将 JSON 字符串转换为实际的 JSON 对象。将多行合并为一行需要 MIN
:
SELECT Id, (
SELECT JSON_QUERY(MIN(CASE WHEN typee = 'APV' THEN jsonStr END)) AS [APV]
, JSON_QUERY(MIN(CASE WHEN typee = 'VN' THEN jsonStr END)) AS [VN]
, JSON_QUERY(MIN(CASE WHEN typee = 'VO' THEN jsonStr END)) AS [VO]
FROM t AS x
WHERE x.id = t.id
FOR JSON AUTO, WITHOUT_ARRAY_WRAPPER
)
FROM t
GROUP BY Id
关于json - 将多行中的 JSON 对象合并为单个对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59087080/