”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > SQL Server 2016中如何从JSON对象数组中提取值数组?

SQL Server 2016中如何从JSON对象数组中提取值数组?

发布于2025-04-18
浏览:237

[2

SQL Server 2016:将JSON对象数组转换为值数组How to Extract an Array of Values from an Array of JSON Objects in SQL Server 2016?

SQL Server 2016的JSON功能很强,但是提取特定数据结构有时需要创造性的方法。 此示例演示了将json对象数组转换为更简单的值。

考虑一个生成json对象数组的查询:

这会产生这样的JSON: [2 “ IDS”:[[ {“ item_id”:“ 1234”}, {“ item_id”:“ 5678”}, {“ item_id”:“ 7890”} 这是给 }

的目标是将其重组为仅包含

item_id
SELECT (SELECT item_id 
FROM #temp
FOR JSON PATH, root('ids')) 
解决方案:

键是一个两步过程,将XML作为中介:
{
  "ids": [
    {"item_id": "1234"},
    {"item_id": "5678"},
    {"item_id": "7890"}
  ]
}

此代码首先使用XML Path('') item_id

值的
{
  "ids": [
    "1234",
    "5678",
    "7890"
  ]
}
json_query

parses。 最后,对于JSON路径,没有_array_wrapper 将输出格式化为简单的JSON数组。 这有效地将原始的JSON对象数组弄平到所需的值数组。

最新教程 更多>

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3