码迷,mamicode.com
首页 > 数据库 > 详细

SqlServer 操作 Json

时间:2019-10-30 11:58:35      阅读:131      评论:0      收藏:0      [点我收藏+]

标签:tar   href   doc   判断   pen   适用于   存储   str   rop   

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

标签:tar   href   doc   判断   pen   适用于   存储   str   rop   

原文地址:https://www.cnblogs.com/Taylor-Luo/p/11763777.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!