如何将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