如何将 json 字符串解析为 SQL 服务器中的扁平行?
How to parse a json string to flat rows in SQL Server?
我在一个文件中有如下数据,我将其读入 SQL 服务器中的一个变量:
{
"TypeCode": [
{
"DestinationValue": "Private",
"SourceValue": "1"
},
{
"DestinationValue": "Public",
"SourceValue": "2"
}
],
"TypeDesc": [
{
"DestinationValue": "Hello",
"SourceValue": "1"
},
{
"DestinationValue": "Bye",
"SourceValue": "2"
}
]
}
现在我需要将其转换成如下数据:
Name SourceValue DestValue
--------------------------------------------
TypeCode 1 Hello
TypeCode 2 Bye
问题是 - 此 JSON 中可能有很多这样的数组,代码应该能够自动处理所有这些数组而无需更改代码。
我们怎样才能做到这一点?
您需要使用 OPENJSON()
解析输入 JSON 两次(使用默认和显式模式):
SELECT j1.[key] AS Name, j2.SourceValue, j2.DestinationValue
FROM OPENJSON(@json) j1
OUTER APPLY OPENJSON(j1.[value]) WITH (
SourceValue nvarchar(100) '$.SourceValue',
DestinationValue nvarchar(100) '$.DestinationValue'
) j2
结果:
Name SourceValue DestinationValue
TypeCode 1 Private
TypeCode 2 Public
TypeDesc 1 Hello
TypeDesc 2 Bye
我在一个文件中有如下数据,我将其读入 SQL 服务器中的一个变量:
{
"TypeCode": [
{
"DestinationValue": "Private",
"SourceValue": "1"
},
{
"DestinationValue": "Public",
"SourceValue": "2"
}
],
"TypeDesc": [
{
"DestinationValue": "Hello",
"SourceValue": "1"
},
{
"DestinationValue": "Bye",
"SourceValue": "2"
}
]
}
现在我需要将其转换成如下数据:
Name SourceValue DestValue
--------------------------------------------
TypeCode 1 Hello
TypeCode 2 Bye
问题是 - 此 JSON 中可能有很多这样的数组,代码应该能够自动处理所有这些数组而无需更改代码。
我们怎样才能做到这一点?
您需要使用 OPENJSON()
解析输入 JSON 两次(使用默认和显式模式):
SELECT j1.[key] AS Name, j2.SourceValue, j2.DestinationValue
FROM OPENJSON(@json) j1
OUTER APPLY OPENJSON(j1.[value]) WITH (
SourceValue nvarchar(100) '$.SourceValue',
DestinationValue nvarchar(100) '$.DestinationValue'
) j2
结果:
Name SourceValue DestinationValue
TypeCode 1 Private
TypeCode 2 Public
TypeDesc 1 Hello
TypeDesc 2 Bye