SqlServer 操作 Json

Posted taylor-luo

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SqlServer 操作 Json相关的知识,希望对你有一定的参考价值。

Sql Server 从 2016 开始支持了一些 json 操作,最近的项目里也是好多地方直接用字段直接存成了 json ,需要了解一下怎么在 Sql Server 中操作 JSON.

JSON支持适用于 SqlServer 2016 及以上版本 和 Azure SQL Database。

SqlServer 中内置了一些 JSON 相关的方法:
可以判断一段字符串是否是标准的 json(ISJSON
可以直接查询数据成 json 格式(FOR JSON PATH) 类似于之前的查询一个 xml (FOR XML PATH),
查询一个 json 对象的值(JSON_VALUE)
查询一个 json 数组值
更新一段JSON的内容,修改 JSON 对象里的属性值,删除 JSON 对象里的某一个属性,增加属性
解析一段 json 内容 (OPENJSON)

JSON 操作

JSON 存储

数据库里 JSON 存储一般用 NVARCHAR(MAX) 类型来保存,如果一定是 JSON 形式的数据可以设置一个约束,可以通过 ISJSON 来给字段加约束,详情参考

JSON 属性加索引

要给 JSON 对象的某个属性加字段时,需要增加一个虚拟的列,然后在这个列中建立一个索引。

1 ALTER TABLE Sales.SalesOrderHeader
2 ADD vCustomerName AS JSON_VALUE(Info,$.Customer.Name)
3 
4 CREATE INDEX idx_soh_json_CustomerName
5 ON Sales.SalesOrderHeader(vCustomerName)

 

JSON 基本操作

{
    "name": "小明",
    "info": {
        "address": {
            "province": "河南省",
            "city": "郑州市",
            "district": "郑东新区"
        },
        "hobbies": [
            "篮球",
            "足球",
            "乒乓球"
        ]
    }
}
 1 -- 查询某一属性值
 2 SET @name = JSON_VALUE(@jsonInfo, $.name);
 3 SET @city = JSON_VALUE(@jsonInfo, $.info.address.city);
 4 
 5 -- 查询数组
 6 SET @hobbies = JSON_QUERY(@jsonInfo, $.info.hobbies);
 7 
 8 -- 增加属性 tempProp
 9 
10 SET @jsonInfo = JSON_MODIFY(@jsonInfo, tempProp, 1);
11 
12 -- 删除属性 tempProp
13 SET @jsonInfo = JSON_MODIFY(@jsonInfo, tempProp, null);

 

 

以上是关于SqlServer 操作 Json的主要内容,如果未能解决你的问题,请参考以下文章

SqlServer 操作 Json

SqlServer 操作 JSON

json 个人的vscode的代码片段

实用代码片段将json数据绑定到html元素 (转)

json 可视代码工作室Angular with Firebase片段

vs code 用户代码片段 html.json