一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Sql Server - 詳解SQL Server 中 JSON_MODIFY 的使用

詳解SQL Server 中 JSON_MODIFY 的使用

2020-06-02 14:24Love it or leave it Sql Server

SQL Server 從 2016 開始支持了一些 JSON操作,最近的項目里也是好多地方字段直接存成了 JSON,需要了解一下怎么在SQL Server 中操作 JSON.這篇文章主要介紹了SQL Server 中 JSON_MODIFY 的使用,需要的朋友可以參考下

SQL Server 中 JSON_MODIFY 的使用

Intro

SQL Server 從 2016 開始支持了一些 JSON操作,最近的項目里也是好多地方字段直接存成了 JSON,需要了解一下怎么在SQL Server 中操作 JSON.

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

最近在項目中很多地方字段都是存一個 JSON 字符串,尤其是針對一些有很多不確定的屬性的數據來說,這樣的信息我們一般都放在一個 Extra 之類的字段保存一個 JSON 字符串,由于不確定性很大,很有可能會遇到要修改這個 JSON 字符串結構的問題,在修改 JSON 對象的某一個值和修改 JSON 的結構時都會用到 JSON_MODIFY,今天就來介紹一下 JSON_MODIFY 的使用

示例

直接來看示例:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
-- 適用 append 在數組中追加元素
PRINT JSON_MODIFY(@testJsonValue, 'append $.skills', 'Azure');
 
-- 無效用法,這樣會把屬性更新為字符串
PRINT JSON_MODIFY(@testJsonValue, '$.skills', '["C#","T-SQL","Azure"]');
 
-- 修改數組
PRINT JSON_MODIFY(@testJsonValue, '$.skills', JSON_QUERY('["C#","T-SQL","Azure"]'));
-- 修改數組某個元素
PRINT JSON_MODIFY(@testJsonValue, '$.skills[0]', 'CSharp');
 
 
-- 增加屬嵌套
PRINT JSON_MODIFY(@testJsonValue, '$.Likes', JSON_QUERY('{"Girl": "Alice"}'));
PRINT JSON_MODIFY(@testJsonValue, '$.Likes', JSON_QUERY('{"Animals": ["Dog","Cat"]}'));
 
-- 增加 bool 屬性
PRINT JSON_MODIFY(@testJsonValue, '$.ShowAwardsAfterQuizEnds', CONVERT(BIT, 'false'));
PRINT JSON_MODIFY(@testJsonValue, '$.ShowAwardsAfterQuizEnds', CONVERT(BIT, 1));
 
-- 增加 int 屬性
PRINT JSON_MODIFY(@testJsonValue, '$.TotalWinnersCount', CONVERT(INT, '20'));
PRINT JSON_MODIFY(@testJsonValue, '$.TotalWinnersCount', 20);
 
-- 刪除屬性
PRINT JSON_MODIFY(@testJsonValue, '$.name', NULL);

輸出結果如下圖:

詳解SQL Server 中 JSON_MODIFY 的使用

More

注意:

  • 如果要更新的字段沒有是一個 JSON 對象或是一個數組,那么需要使用 JSON_QUERY ,否則更新的對應的屬性就成了字符串了。
  • 如果是要刪除某一個屬性,把某一個屬性更新為 NULL 即可
  • 如果要增加一個 bool 類型的屬性,需要把對應的值轉換為 BIT 類型

Reference

https://docs.microsoft.com/en-us/sql/t-sql/functions/json-modify-transact-sql?view=sql-server-ver15

https://docs.microsoft.com/en-us/sql/relational-databases/json/json-path-expressions-sql-server?view=sql-server-ver15

總結

以上所述是小編給大家介紹的SQL Server 中 JSON_MODIFY 的使用,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對服務器之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

原文鏈接:https://www.cnblogs.com/weihanli/archive/2019/11/13/11853827.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国内亚州视频在线观看 | 交换年轻夫妇HD中文字幕 | 小鸟酱喷水 | 日韩精品视频美在线精品视频 | 毛片免费的 | 99久久综合给久久精品 | 国产精品美女久久久久 | 四虎国产欧美成人影院 | 日韩成人在线免费视频 | 性德国高清xxxxbbbb | 无敌在线视频观看免费 | 亚洲一区二区日韩欧美gif | 韩国最新理论三级在线观看 | 国产极品久久 | 国产精品一区二区在线观看完整版 | 欧美操屁股 | 羞羞污视频 | 日韩一区二区三区四区区区 | 亚洲日本视频在线 | 香蕉久久一区二区三区 | 视频一区国产精戏刘婷 | 国产在线乱子伦一区二区 | 男人午夜免费视频 | 国产免费成人在线视频 | 性插图动态图无遮挡 | 美女和男人差差 | 欧美日韩国产成人综合在线 | 蜜桃视频一区二区三区四区 | 我与肥熟老妇的性事 | 久久免费国产 | 波多野结在线观看 | 亚洲男男video | 强女明星系列小说 | 调教肉文 | 四虎永久免费地址ww417 | 咪咪爱991 | 国产欧美视频高清va在线观看 | 女人把扒开给男人爽 | 亚州vs欧州vs日 | 亚洲福利一区二区三区 | 高清女主播一区二区三区 |