gpt4 book ai didi

sql-server - T-SQL JSON : How do i search for a value in a JSON array

转载 作者:行者123 更新时间:2023-12-02 18:50:10 24 4
gpt4 key购买 nike

我们正在使用 Azure SQL - 并有一个名为 Companies 的表,其中其中一列包含 JSON。 JSON 字段的结构为:

{
"DepartmentLink": "https://company.com",
"ContactName": "John Doe",
"ContactTitle": "CEO",
"ContactEmail": "john.doe@company.com",
"ContactPhone": "xx xx xx xx xx",
"ContactImage": "https://company.com/xyz.jpg",
"ZipCodes": [
"7000",
"7007",
"7017",
"7018",
"7029"
]
}

表的结构如下所示

[Id] [int] IDENTITY(1,1) NOT NULL,
[Name] [nvarchar](100) NULL,
[JsonString] [nvarchar](max) NULL,
-- other fields --

其中 [JsonString] 具有以下结构:

{
"DepartmentLink": "https://company.com",
"ContactName": "John Doe",
"ContactTitle": "CEO",
"ContactEmail": "john.doe@company.com",
"ContactPhone": "xx xx xx xx xx",
"ContactImage": "https://company.com/xyz.jpg",
"ZipCodes": [
"7000",
"7007",
"7017",
"7018",
"7029"
]
}

给定一个邮政编码,例如7018 我需要找到在 Json Array ZipCodes 中具有此 ZipCode 的公司 - 并从记录中返回元素(这些元素都以普通“字段”形式出现 - 因此我不需要返回 JSON。)。

我在寻找如何执行此操作时遇到问题。有什么建议么?我对 SQL 中的 JSON 很陌生。

最佳答案

使用OPENJSONCROSS APPLY来分解邮政编码数组,然后在过滤器中添加一个WHERE子句,如下所示:

SELECT *, JSON_VALUE( yourJSON, '$.DepartmentLink' ) AS DepartmentLink
FROM dbo.Companies
CROSS APPLY OPENJSON( yourJSON, '$.ZipCodes') x
WHERE x.value = '7000';

关于sql-server - T-SQL JSON : How do i search for a value in a JSON array,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48821936/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com