<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
檔案
方法
JSON_CONTAINS(target, candidate[, path]) value MEMBER OF(json_array)
查詢範例
mysql> set @list = JSON_ARRAY(1, 2); Query OK, 0 rows affected (0.01 sec) mysql> select 1 MEMBER OF(@list); +--------------------+ | 1 MEMBER OF(@list) | +--------------------+ | 1 | +--------------------+ 1 row in set (0.00 sec) mysql> SELECT JSON_CONTAINS(@list, '1'); +---------------------------+ | JSON_CONTAINS(@list, '1') | +---------------------------+ | 1 | +---------------------------+ 1 row in set (0.01 sec)
Mysql 自5.7之後增加了很多函數用於處理Json字串。方便實用。
Json陣列:
["abc", 10, null, true, false]
Json物件:
{"k1": "value", "k2": 10}
JSON陣列元素和JSON物件鍵值內允許巢狀
JSON_TYPE()
:返回json字串型別mysql> SELECT JSON_TYPE('["a", "b", 1]'); +----------------------------+ | JSON_TYPE('["a", "b", 1]') | +----------------------------+ | ARRAY | +----------------------------+ mysql> SELECT JSON_TYPE('"hello"'); +----------------------+ | JSON_TYPE('"hello"') | +----------------------+ | STRING | +----------------------+ mysql> SELECT JSON_TYPE('hello'); ERROR 3146 (22032): Invalid data type for JSON data in argument 1 to function json_type; a JSON string or JSON type is required.
MySQL使用utf8mb4字元集和utf8mb4_bin排序規則處理JSON上下文中使用的字串 。其他字元集中的字串將utf8mb4根據需要轉換。(對於ascii或 utf8字元集中的字串,無需進行轉換,因為ascii和utf8是的子集utf8mb4。一般將資料庫字元集設定為utf8mb4)
JSON_ARRAY()
:將數值包裝為json陣列mysql> SELECT JSON_ARRAY('a', 1, NOW()); +----------------------------------------+ | JSON_ARRAY('a', 1, NOW()) | +----------------------------------------+ | ["a", 1, "2015-07-27 09:43:47.000000"] | +----------------------------------------+
JSON_OBJECT()
:將數值包裝為json物件mysql> SELECT JSON_OBJECT('key1', 1, 'key2', 'abc'); +---------------------------------------+ | JSON_OBJECT('key1', 1, 'key2', 'abc') | +---------------------------------------+ | {"key1": 1, "key2": "abc"} | +---------------------------------------+
JSON_MERGE()
:將多個json合併為一個mysql> SELECT JSON_MERGE('["a", 1]', '{"key": "value"}'); +--------------------------------------------+ | JSON_MERGE('["a", 1]', '{"key": "value"}') | +--------------------------------------------+ | ["a", 1, {"key": "value"}] | +--------------------------------------------+
Json字串中的key-value存取
使用column-path運運算元 ->得到欄位中json某個key的值,但是值中的"""和""都會顯示,如果不想顯示,使用->>。
#建立表 CREATE TABLE facts (ids JSON); #插入資料 這裡要注意是否啟用了伺服器SQL模式,插入資料時要注意特殊符號 INSERT INTO facts VALUES (JSON_OBJECT('mascot', 'Our mascot is a dolphin named "Sakila".')); #檢視資料 mysql> select ids from facts; +---------------------------------------------------------+ | ids | +---------------------------------------------------------+ | {"mascot": "Our mascot is a dolphin named "Sakila"."} | +---------------------------------------------------------+ 1 row in set (0.00 sec)
mysql> SELECT ids->'$.mascot' FROM facts; +---------------------------------------------+ | ids->'$.mascot' | +---------------------------------------------+ | "Our mascot is a dolphin named "Sakila"." | +---------------------------------------------+ 1 row in set (0.00 sec) mysql> SELECT ids->>'$.mascot' FROM facts; +-----------------------------------------+ | ids->>'$.mascot' | +-----------------------------------------+ | Our mascot is a dolphin named "Sakila". | +-----------------------------------------+ #注意,這裡存取json欄位key使用單引號還是雙引號取決於sql模式
讀取json欄位中某個key的值
SELECT JSON_EXTRACT('{"id": 14, "name": "Aztalan"}', '$.name'); +---------------------------------------------------------+ | JSON_EXTRACT('{"id": 14, "name": "Aztalan"}', '$.name') | +---------------------------------------------------------+ | "Aztalan" | +---------------------------------------------------------+ #去除值雙引號 mysql> SELECT JSON_UNQUOTE(JSON_EXTRACT('{"id": 14, "name": "Aztalan"}', '$.name')); +-----------------------------------------------------------------------+ | JSON_UNQUOTE(JSON_EXTRACT('{"id": 14, "name": "Aztalan"}', '$.name')) | +-----------------------------------------------------------------------+ | Aztalan | +-----------------------------------------------------------------------+
小結:
‘$.*’ | 返回全部json |
‘$.title’ | 返回key=”title”的資料 |
‘$**.text’ | 返回所有最底層key=”text”的資料 |
‘$.content[*].item1[*]’ | 返回key=content的list的key=item1的list的所有內容 |
以上為個人經驗,希望能給大家一個參考,也希望大家多多支援it145.com。
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45