sqlserver慕课_SqlServer 操作 Json

SqlServer 操作 JSON

Intro

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 对象的某个属性加字段时,需要增加一个虚拟的列,然后在这个列中建立一个索引。ALTER TABLE Sales.SalesOrderHeaderADD vCustomerName AS JSON_VALUE(Info,'$.Customer.Name')CREATE INDEX idx_soh_json_CustomerNameON Sales.SalesOrderHeader(vCustomerName)

JSON 基本操作{    "name": "小明",    "info": {        "address": {            "province": "河南省",            "city": "郑州市",            "district": "郑东新区"

},        "hobbies": [            "篮球",            "足球",            "乒乓球"

]

}

}-- 查询某一属性值SET @name = JSON_VALUE(@jsonInfo, '$.name');SET @city = JSON_VALUE(@jsonInfo, '$.info.address.city');-- 查询数组SET @hobbies = JSON_QUERY(@jsonInfo, '$.info.hobbies');-- 增加属性 tempPropSET @jsonInfo = JSON_MODIFY(@jsonInfo, 'tempProp', 1);-- 删除属性 tempPropSET @jsonInfo = JSON_MODIFY(@jsonInfo, 'tempProp', null);

作者:天天向上卡索

链接:https://www.jianshu.com/p/34b77a0fba6d

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值