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