如何解决如何将json字符串解析为SQL Server中的平面行?
我在SQL Server中读入变量的文件中具有以下数据:
{
"TypeCode": [
{
"DestinationValue": "Private","SourceValue": "1"
},{
"DestinationValue": "Public","SourceValue": "2"
}
],"TypeDesc": [
{
"DestinationValue": "Hello",{
"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
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。