似乎最简单的方法是使用子查询来读取 JSON,并创建新的: STRING_AGG
SELECT V.ID,
V.Name,
'[' + STRING_AGG('"' + ca.FieldName + '"',',') WITHIN GROUP (ORDER BY ca.FieldName) + ']'
FROM (VALUES(7,'Query 7','[{"FieldName": "A"},{ "FieldName": "B"},{"FieldName": "B"}]'))V(ID,[Name], Query)
CROSS APPLY (SELECT DISTINCT OJ.FieldName
FROM OPENJSON (V.Query)
WITH (FieldName char(1)) OJ) ca --May need larger size, char(1) based on your sample data
GROUP BY V.ID,
V.[Name];
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。