mysql之json高級使用

前言

JSON是一種輕量級的數(shù)據(jù)交換格式敏晤,采用了獨立于語言的文本格式,類似XML舆乔,但是比XML簡單壁袄,易讀并且易編寫伸刃。對機器來說易于解析和生成,并且會減少網(wǎng)絡(luò)帶寬的傳輸。

JSON的格式非常簡單:名稱/鍵值。之前MySQL版本里面要實現(xiàn)這樣的存儲驱负,要么用VARCHAR要么用TEXT大文本。 MySQL5.7發(fā)布后患雇,專門設(shè)計了JSON數(shù)據(jù)類型以及關(guān)于這種類型的檢索以及其他函數(shù)解析跃脊。

下面一起來實際操作一下。

創(chuàng)建帶有 JSON 字段的表

比如一個‘文章'表苛吱,字段包括

id匾乓、標(biāo)題 title、標(biāo)簽 tags

一篇文章會有多個標(biāo)簽又谋,tags 就可以設(shè)為 JSON 類型

建表語句如下:

`CREATE` `TABLE` ``article` (`

``id` mediumint(8) unsigned` `NOT` `NULL` `AUTO_INCREMENT,`

``title`` `varchar``(200)` `NOT` `NULL``,`

``tags` json` `DEFAULT` `NULL``,`

`PRIMARY` `KEY` `(`id`)`

`) ENGINE=InnoDB;`

插入數(shù)據(jù)

插入一條帶有 JSON 內(nèi)容的數(shù)據(jù)拼缝,執(zhí)行 insert 語句:

`INSERT` `INTO` ``article` (`title`, `tags`)`

`VALUES` `(`

`'體驗 Mysql JSON'``,`

`'["Mysql", "Database"]'`

`);`

這里插入的是一個 JOSN 數(shù)組[“Mysql”, “Database”]

查詢 article 表中的所有內(nèi)容,可以看到新插入的這條數(shù)據(jù)

[圖片上傳失敗...(image-f42670-1572915815088)]

查詢

使用 JSON 函數(shù)做兩個簡單的查詢

1.查找?guī)в袠?biāo)簽”Mysql”的所有文章


`SELECT` `*` `FROM` ``article``

`WHERE` `JSON_CONTAINS(tags,` `'["Mysql"]'``);`

2.查找標(biāo)簽中以”Data”開頭的文章


`SELECT` `*` `FROM` ``article``

`WHERE` `JSON_SEARCH(tags,` `'one'``,` `'Data%'``)` `IS` `NOT` `NULL``;`

JSON_SEARCH 函數(shù)中3個參數(shù)的含義:

1.要查找的文檔

2.查找的范圍彰亥,有兩個選項咧七,'one' 查找第一個符合條件的,'all'查找所有符合條件的

3.查找的條件

JSON Path

JSON Path用來定位文檔中的目標(biāo)字段任斋,例如

`SELECT` `JSON_EXTRACT(`

`'{"id": 1, "name": "mysql"}'``,`

`'$.name'`

`);`

結(jié)果為:mysql

JSON_EXTRACT() 是JSON提取函數(shù)继阻,$.name 就是一個 JSON path,表示定位文檔的 name 字段

JSON path 是以 $ 開頭废酷,下面看幾個更多的示例


`{`

`"num"``: 123,`

`"arr"``: [1, 2],`

`"obj"``: {`

`"a"``: 3,`

`"b"``: 4`

`}`

`}`

`$.num //結(jié)果:123`

`$.arr //結(jié)果:[1, 2]`

`$.arr[1] //結(jié)果:1`

`$.obj.a //結(jié)果:3`

`$**.b //結(jié)果:4`

使用 JSON path 的查詢示例


`SELECT`

`tags->``"$[0]"` `as` `'tag'`

`FROM` ``article`;`

更新數(shù)據(jù)

例如想給文章添加一個 “dev” tag瘟檩,更新的條件是已經(jīng)包含 “Mysql” 標(biāo)簽,并且還沒有 “dev” 標(biāo)簽的數(shù)據(jù)

更新語句如下:


`UPDATE` ``article``

`SET` `tags = JSON_MERGE(tags,` `'["dev"]'``)`

`WHERE`

`JSON_SEARCH(tags,` `'one'``,` `'dev'``)` `IS` `NULL`

`AND`

`JSON_SEARCH(tags,` `'one'``,` `'Mysql'``)` `IS` `NOT` `NULL``;`

[圖片上傳失敗...(image-4da238-1572915815088)]

可以看到成功添加了 “dev” 標(biāo)簽

再比如想把 “Mysql” 這個標(biāo)簽更新為 “Mysql 5.7.13″澈蟆,更新語句如下:


`UPDATE` ``article`` `set` `tags = JSON_SET(tags, ‘$[0]``', ‘Mysql 5.7.13'``) ;`

上面體驗了 JSON_MERGEJSON_SET墨辛,用于修改JSON的函數(shù)還有很多,例如:


`JSON_INSERT(doc, path, val[, path, val]…)`

插入數(shù)據(jù)


`JSON_REPLACE(doc, path, val[, path, val]…)`

替換數(shù)據(jù)


`JSON_ARRAY_APPEND(doc, path, val[, path, val]…)`

向數(shù)組尾部追加數(shù)據(jù)

`JSON_REMOVE(doc, path[, path]…)`

從指定位置移除數(shù)據(jù)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末趴俘,一起剝皮案震驚了整個濱河市睹簇,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌寥闪,老刑警劉巖太惠,帶你破解...
    沈念sama閱讀 211,042評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異疲憋,居然都是意外死亡凿渊,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評論 2 384
  • 文/潘曉璐 我一進店門缚柳,熙熙樓的掌柜王于貴愁眉苦臉地迎上來埃脏,“玉大人,你說我怎么就攤上這事喂击〖涟” “怎么了?”我有些...
    開封第一講書人閱讀 156,674評論 0 345
  • 文/不壞的土叔 我叫張陵翰绊,是天一觀的道長佩谷。 經(jīng)常有香客問我,道長监嗜,這世上最難降的妖魔是什么谐檀? 我笑而不...
    開封第一講書人閱讀 56,340評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮裁奇,結(jié)果婚禮上桐猬,老公的妹妹穿的比我還像新娘。我一直安慰自己刽肠,他們只是感情好溃肪,可當(dāng)我...
    茶點故事閱讀 65,404評論 5 384
  • 文/花漫 我一把揭開白布免胃。 她就那樣靜靜地躺著,像睡著了一般惫撰。 火紅的嫁衣襯著肌膚如雪羔沙。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,749評論 1 289
  • 那天厨钻,我揣著相機與錄音扼雏,去河邊找鬼。 笑死夯膀,一個胖子當(dāng)著我的面吹牛诗充,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播诱建,決...
    沈念sama閱讀 38,902評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼蝴蜓,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了涂佃?” 一聲冷哼從身側(cè)響起励翼,我...
    開封第一講書人閱讀 37,662評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎辜荠,沒想到半個月后汽抚,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,110評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡伯病,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年造烁,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片午笛。...
    茶點故事閱讀 38,577評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡惭蟋,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出药磺,到底是詐尸還是另有隱情告组,我是刑警寧澤,帶...
    沈念sama閱讀 34,258評論 4 328
  • 正文 年R本政府宣布癌佩,位于F島的核電站木缝,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏围辙。R本人自食惡果不足惜我碟,卻給世界環(huán)境...
    茶點故事閱讀 39,848評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望姚建。 院中可真熱鬧矫俺,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至催烘,卻和暖如春沥阱,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背伊群。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留策精,地道東北人舰始。 一個月前我還...
    沈念sama閱讀 46,271評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像咽袜,于是被迫代替她去往敵國和親丸卷。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,452評論 2 348

推薦閱讀更多精彩內(nèi)容