如何解决使用CROSS APPLY OPENJSON...WITHkey时如何浏览给定的键列表?
CREATE TABLE #Keys (k NVARCHAR(10));
INSERT INTO #Keys VALUES ('key1'),('key2'),('key3');
CREATE TABLE #Data ( v NVARCHAR(MAX) )
INSERT INTO #Data
VALUES ( N'{"key1":{"1":{}},"key2":{"1":{}}}' )
SELECT *
FROM #Data J
CROSS APPLY OPENJSON(J.v) WITH (key1 NVARCHAR(MAX) AS JSON) key1
CROSS APPLY OPENJSON(J.v) WITH (key2 NVARCHAR(MAX) AS JSON) key2
CROSS APPLY OPENJSON(J.v) WITH (key3 NVARCHAR(MAX) AS JSON) key3
我该如何浏览#keys中的字段,而不是在CROSS APPLY中对其进行硬编码?
预期结果:
key1 | key2 | key3
{"1":{}} | {"1":{}} | NULL
解决方法
在访问具有无效JSON名称的字段时(例如,字段以数字开头/结尾时),请使用双引号。否则,无法通过简单地说“从nested_json中选择*”来拼合数据。
SELECT *,JSON_VALUE(key1.key1,'$."1"') jv1,JSON_VALUE(key2.key2,'$."1"') jv2,JSON_VALUE(key3.key3,'$') jv3
FROM #Data J
CROSS APPLY OPENJSON(J.v) WITH (key1 NVARCHAR(MAX) AS JSON) key1
CROSS APPLY OPENJSON(J.v) WITH (key2 NVARCHAR(MAX) AS JSON) key2
CROSS APPLY OPENJSON(J.v) WITH (key3 NVARCHAR(MAX) AS JSON) key3;
编辑:要在#Keys.k和j。[Key]之间加入,排序规则必须相同。在这里,我将#Key的DDL切换为Latin1_General_BIN2。
CREATE TABLE #Keys (k NVARCHAR(10) collate Latin1_General_BIN2);
INSERT INTO #Keys VALUES ('key1'),('key2'),('key3');
CREATE TABLE #Data ( v NVARCHAR(MAX) )
INSERT INTO #Data
VALUES ( N'{"key1":{"1":{}},"key2":{"1":{}}}' )
SELECT *
FROM
#Data J
CROSS APPLY
OPENJSON(J.v) oj
join
#Keys k on oj.[key]=k.k;
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。