mysql中json的使用方式詳解
mysql字段的數(shù)據(jù)類型支持json格式,可以直接存儲json數(shù)組和json對象。
一、插入json數(shù)據(jù)的方式有兩種
1、以普通字符串形式插入,需要遵循 json 格式
2、用 內(nèi)置函數(shù)(JSON_OBJECT和JSON_ARRAY)創(chuàng)建JSON數(shù)據(jù)再插入
二、查詢 JSON 中字段的數(shù)據(jù)
1、column -> 'path' 和 JSON_EXTRACT(column, 'path')形式訪問指定字段的具體數(shù)據(jù)。(*注意path外面都要用單引號包起來)
其中 column 表示要查詢的數(shù)據(jù)字段列名;
path 為 JSON 數(shù)據(jù)的訪問路徑,path格式為 $.path 或 $[idx]。
$.path 用于 JSON對象類型數(shù)據(jù);
$[idx] 用于 JSON數(shù)組類型數(shù)據(jù);
$ 代表整個 JSON 數(shù)據(jù)的 root 節(jié)點;
path 為訪問字段 key,如果字段名包含空格,則需要用雙引號包住,如 $."nick name";(*注意中文字段名也需要雙引號包住)
[idx] 是數(shù)組的索引。
2、->
和JSON_EXTRACT查詢到的字段字符串類型還會有個雙引號,還需要做一層處理,可以使用 ->>和JSON_UNQUOTE
去除,且轉義符也會去除。
JSON_UNQUOTE(JSON_EXTRACT(column, path)) 等價于 column->>path
3、多級查詢的方式有兩種:
① column -> '$.key.childKey' path點號連接子集字段的方式訪問
② JSON_EXTRACT(JSON_EXTRACT(column, path), path) JSON_EXTRACT嵌套的方式
③column->'$[*].key' 可以查詢json數(shù)組所有key,返回數(shù)組
三、JSON字段的條件搜索
1、精確查詢json類型字段
where column-> '$.key' = value
2、模糊查詢JsonArray類型字段
where column->'$[*].key' like '%value%'
3、精確查詢JsonArray類型字段
where JSON_CONTAINS(column,JSON_OBJECT('key', "value"))
4、多層級關系,模糊查詢所有的
where column->'$**.key' like '%value%'
四、JSON字段的更新操作 1、更新字段
JSON_SET(column, path, val[, path, val] ...) 更新或插入
JSON_REPLACE(column, path, val[, path, val] ...) 只更新
2、新增字段
JSON_INSERT(column, path, val[, path, val] ...) 插入新字段,不會改變已經(jīng)存在的
3、刪除字段
JSON_REMOVE(column, path[, path] ...) 刪除字段
到此這篇關于mysql中json的使用的文章就介紹到這了,更多相關mysql中json使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
MySQL報錯:The?server?quit?without?updating?PID?file的解決思路
最近在學習mysql二進制的時候遇到了個報錯,解決分享給大家,這篇文章主要給大家介紹了關于MySQL報錯:The?server?quit?without?updating?PID?file的解決思路與方法,需要的朋友可以參考下2023-02-02MySQL5.73?root用戶密碼修改方法及ERROR?1193、ERROR1819與ERROR1290報錯解決
這篇文章主要給大家介紹了關于MySQL5.73?root用戶密碼修改方法及ERROR?1193、ERROR1819與ERROR1290:...?running?with?--skip-...報錯的解決方法,文中通過圖文將解決的步驟介紹的非常詳細,需要的朋友可以參考下2023-02-02