欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL之JSON類(lèi)型字段的使用技巧分享

 更新時(shí)間:2022年08月25日 14:37:39   作者:keep丶  
這篇文章主要介紹了MySQL之JSON類(lèi)型字段的使用技巧,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

測(cè)試環(huán)境: MySQL8.0.19

準(zhǔn)備工作

CREATE TABLE json_demo ( 
	`id` INT ( 11 ) NOT NULL PRIMARY KEY, 
	`content` json NOT NULL 
);
INSERT INTO json_demo ( id, content )
VALUES
	/*這條是數(shù)組*/
	( 1, '[{"key": 1, "order": 1, "value": "34252"},{"key": 2, "order": 2, "value": "23423"}]' ),
	/*這條是數(shù)組*/
	( 2, '[{"key": 4, "order": 4, "value": "234"},{"key": 5, "order": 5, "value": "234324523"}]' ),
	/*這條是對(duì)象*/
	( 3, '{"key": 3, "order": 3, "value": "43242"}' ),
	/*這條是對(duì)象*/
	( 4, '{"key": 6, "order": 6, "value": "5423"}' );

JSON對(duì)象基礎(chǔ)操作

查詢(xún)指定字段值

/* 基礎(chǔ)查詢(xún) */
SELECT
	content -> '$.key' AS 'key',
	JSON_EXTRACT(content, '$.key') AS 'key2',
	content -> '$.value' AS 'value',
	JSON_EXTRACT(content, '$.value') AS 'value2',
	content ->> '$.value' AS 'value3',
	JSON_UNQUOTE(JSON_EXTRACT(content, '$.value')) AS 'value4'
FROM
	json_demo 
WHERE
	id > 2;

TIPS:

  • ->和->>是MySQL設(shè)計(jì)的語(yǔ)法,其中->在MySQL5.7支持,->>在MySQL8.0中支持。
  • ->等效于JSON_EXTRACT(),當(dāng)查詢(xún)字段為字符串時(shí),其返回值還會(huì)帶有""。
  • ->>等效于JSON_UNQUOTE(JSON_EXTRACT()),當(dāng)查詢(xún)字段為字符串時(shí),其返回值不會(huì)帶有""。

用于條件查詢(xún)

content -> '$.key'可以看成一個(gè)字段,一個(gè)字段能做的操作基本他都能。

SELECT
	id,
	content -> '$.key' AS 'key',
	content ->> '$.value' AS 'value3'
FROM
	json_demo 
WHERE
	id > 2
	AND content -> '$.key' > 1
	AND content -> '$.value' like '%2%';

修改指定字段值

/* 修改 */
UPDATE json_demo 
SET content = JSON_REPLACE(
	content,
	/* 將content.key值 + 1 */
	'$.key', content -> '$.key' + 1,
	/* 將content.value值后拼接'abc' */
	'$.value', concat(content ->> '$.value', 'abc')
) WHERE id = 3;
/* JSON_SET也可以 */
UPDATE json_demo 
SET content = JSON_SET(
	content,
	/* 將content.key值 + 1 */
	'$.key', content -> '$.key' + 1,
	/* 將content.value值后拼接'abc' */
	'$.value', concat(content ->> '$.value', 'abc')
) WHERE id = 3;
/* 查詢(xún)修改結(jié)果 */
SELECT id,content,content -> '$.key' AS 'key',content ->> '$.value' AS 'value3'
FROM json_demo WHERE id = 3;
/* 重新賦值 */
UPDATE json_demo SET 
content = JSON_REPLACE(content,'$.key',3,'$.value','43242') WHERE id = 3;

TIPS:

  • JSON_REPLACE和JSON_SET都可以用來(lái)修改某個(gè)字段值,區(qū)別在于JSON_REPLACE替換不存在的屬性時(shí)操作無(wú)效;而JSON_SET則會(huì)將這個(gè)不存在的屬性插入進(jìn)去。
  • 所以JSON_SET也可以用來(lái)追加屬性,與JSON_INSERT類(lèi)似。區(qū)別在于JSON_INSERT如果插入一個(gè)已存在的屬性時(shí)操作會(huì)失效,而JSON_SET會(huì)替換。

追加元素

UPDATE json_demo 
SET content = JSON_INSERT(content, '$.key', 234)
WHERE id = 3;

SELECT id,content,content -> '$.key' AS 'key' FROM json_demo WHERE id = 3;

UPDATE json_demo 
SET content = JSON_INSERT(content, '$.temp', 234)
WHERE id = 3;

SELECT id,content,content -> '$.key' AS 'key' FROM json_demo WHERE id = 3;

UPDATE json_demo 
SET content = JSON_SET(content, '$.temp2', 432)
WHERE id = 3;

SELECT id,content,content -> '$.key' AS 'key' FROM json_demo WHERE id = 3;

JSON數(shù)組操作

查詢(xún)指定字段值

SELECT
	id,
	content -> '$[*].key' AS 'key',
	content ->> '$[*].value' AS 'value',
	content -> '$[0].key' AS 'key2',
	content ->> '$[0].value' AS 'value2',
	/* 查詢(xún)數(shù)組長(zhǎng)度 */
	JSON_LENGTH(content) AS 'length'
FROM
	json_demo 
WHERE
	id < 3;

用于條件查詢(xún)

SELECT
	id,
	content -> '$[*].key' AS 'key',
	content ->> '$[*].value' AS 'value'
FROM
	json_demo 
WHERE
	id < 3
	/* content.value的值中存在like'%34%'的值 */
	AND content ->> '$[*].value' like '%34%'
	/* content.key的值中有4 */
	AND JSON_OVERLAPS(content ->> '$[*].key', '4' );

修改指定字段值

基礎(chǔ)操作都跟JSON對(duì)象差不太多,就是在'$'后面加對(duì)應(yīng)的索引位'$[0]',指定所有則'$[*]'。如果數(shù)組中包含數(shù)組,可以通過(guò)'$[1][2][3]'這種方式指定深層的數(shù)組元素。

追加元素

JSON_ARRAY_APPEND和JSON_ARRAY_INSERT都可以實(shí)現(xiàn)數(shù)組元素追加。區(qū)別在于JSON_ARRAY_APPEND可以不指定索引位,此時(shí)往最后位置追加;JSON_ARRAY_INSERT必須指定索引位,不指定則會(huì)報(bào)錯(cuò)。

JSON_ARRAY_APPEND是追加在指定索引位后面,而JSON_ARRAY_INSERT則是插入到指定索引位前面。

更多操作

名稱(chēng)描述
JSON_ARRAY()創(chuàng)建JSON數(shù)組
JSON_ARRAY_APPEND()將數(shù)據(jù)附加到JSON文檔
JSON_ARRAY_INSERT()插入JSON數(shù)組
JSON_CONTAINS()JSON文檔是否在路徑中包含特定對(duì)象
JSON_CONTAINS_PATH()JSON文檔是否在路徑中包含任何數(shù)據(jù)
JSON_DEPTH()JSON文檔的最大深度
JSON_EXTRACT()從JSON文檔返回?cái)?shù)據(jù)
JSON_INSERT()將數(shù)據(jù)插入JSON文檔
JSON_KEYS()JSON文檔中的鍵數(shù)組
JSON_LENGTH()JSON文檔中的元素?cái)?shù)
JSON_MERGE() (已棄用)合并JSON文檔,保留重復(fù)的鍵。JSON_MERGE_PRESERVE()的已棄用同義詞
JSON_MERGE_PATCH()合并JSON文檔,替換重復(fù)鍵的值
JSON_MERGE_PRESERVE()合并JSON文檔,保留重復(fù)的鍵
JSON_OBJECT()創(chuàng)建JSON對(duì)象
JSON_OVERLAPS() (8.0.17引入)比較兩個(gè)JSON文檔,如果它們具有共同的任何鍵值對(duì)或數(shù)組元素,則返回TRUE(1),否則返回FALSE(0)
JSON_PRETTY()以易于閱讀的格式打印JSON文檔
JSON_QUOTE()引用JSON文檔
JSON_REMOVE()從JSON文檔中刪除數(shù)據(jù)
JSON_REPLACE()替換JSON文檔中的值
JSON_SCHEMA_VALID() (8.0.17引入)根據(jù)JSON模式驗(yàn)證JSON文檔;如果文檔針對(duì)架構(gòu)進(jìn)行了驗(yàn)證,則返回TRUE / 1;否則,則返回FALSE / 0。
JSON_SCHEMA_VALIDATION_REPORT() (8.0.17引入)根據(jù)JSON模式驗(yàn)證JSON文檔;以JSON格式返回有關(guān)驗(yàn)證結(jié)果的報(bào)告,包括成功或失敗以及失敗原因
JSON_SEARCH()JSON文檔中值的路徑
JSON_SET()將數(shù)據(jù)插入JSON文檔
JSON_STORAGE_FREE()部分更新后,JSON列值的二進(jìn)制表示形式中的可用空間
JSON_STORAGE_SIZE()用于存儲(chǔ)JSON文檔的二進(jìn)制表示形式的空間
JSON_TABLE()從JSON表達(dá)式返回?cái)?shù)據(jù)作為關(guān)系表
JSON_TYPE()JSON值類(lèi)型
JSON_UNQUOTE()取消引用JSON值
JSON_VALID()JSON值是否有效
JSON_VALUE() (8.0.21引入)在提供的路徑所指向的位置從JSON文檔中提取值;以VARCHAR(512)或指定的類(lèi)型返回此值
MEMBER OF() (8.0.17引入)如果第一個(gè)操作數(shù)與作為第二個(gè)操作數(shù)傳遞的JSON數(shù)組的任何元素匹配,則返回true(1),否則返回false(0)

JSON字段在JAVA中的實(shí)踐

這個(gè)是我的另外一篇關(guān)于JSON字段實(shí)踐:

Mysql json類(lèi)型字段Java+Mybatis數(shù)據(jù)字典功能實(shí)踐

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • CentOS7環(huán)境下安裝MySQL5.5數(shù)據(jù)庫(kù)

    CentOS7環(huán)境下安裝MySQL5.5數(shù)據(jù)庫(kù)

    大家好,本篇文章主要講的是CentOS7環(huán)境下安裝MySQL5.5數(shù)據(jù)庫(kù),感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • Mysql關(guān)于進(jìn)程中的死鎖和解除鎖問(wèn)題

    Mysql關(guān)于進(jìn)程中的死鎖和解除鎖問(wèn)題

    Mysql 經(jīng)常會(huì)遇到語(yǔ)句或者存儲(chǔ)過(guò)程長(zhǎng)時(shí)間沒(méi)有反應(yīng),大概率就是掛掉了,或者死鎖了,這篇文章主要介紹了Mysql關(guān)于進(jìn)程中的死鎖和解除鎖問(wèn)題,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-07-07
  • mysql中IFNULL,IF,CASE的區(qū)別介紹

    mysql中IFNULL,IF,CASE的區(qū)別介紹

    本文將詳細(xì)介紹mysql中IFNULL,IF,CASE的區(qū)別,需要了解的朋友可以參考下
    2012-11-11
  • 面試提問(wèn)mysql一張表到底能存多少數(shù)據(jù)

    面試提問(wèn)mysql一張表到底能存多少數(shù)據(jù)

    這篇文章主要為大家介紹了面試提問(wèn)mysql一張表到底能存多少數(shù)據(jù)的問(wèn)題分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2022-03-03
  • MySQL分組查詢(xún)、排序查詢(xún)、分頁(yè)查詢(xún)以及執(zhí)行順序

    MySQL分組查詢(xún)、排序查詢(xún)、分頁(yè)查詢(xún)以及執(zhí)行順序

    MySQL數(shù)據(jù)查詢(xún)是數(shù)據(jù)庫(kù)操作中最常見(jiàn)的操作之一,它可以幫助我們從數(shù)據(jù)庫(kù)中獲取所需的數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于MySQL分組查詢(xún)、排序查詢(xún)、分頁(yè)查詢(xún)以及執(zhí)行順序的相關(guān)資料,需要的朋友可以參考下
    2024-02-02
  • mysql5.7.17安裝使用圖文教程

    mysql5.7.17安裝使用圖文教程

    這篇文章主要為大家詳細(xì)介紹了MySql安裝與使用圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • Mysql四種分區(qū)方式以及組合分區(qū)落地實(shí)現(xiàn)詳解

    Mysql四種分區(qū)方式以及組合分區(qū)落地實(shí)現(xiàn)詳解

    對(duì)用戶(hù)來(lái)說(shuō),分區(qū)表是一個(gè)獨(dú)立的邏輯表,但是底層由多個(gè)物理子表組成,下面這篇文章主要給大家介紹了關(guān)于Mysql四種分區(qū)方式以及組合分區(qū)落地實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考下
    2022-04-04
  • MySQL MyISAM默認(rèn)存儲(chǔ)引擎實(shí)現(xiàn)原理

    MySQL MyISAM默認(rèn)存儲(chǔ)引擎實(shí)現(xiàn)原理

    這篇文章主要介紹了MySQL MyISAM默認(rèn)存儲(chǔ)引擎實(shí)現(xiàn)原理,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • Windows下MySQL主從復(fù)制的配置方法

    Windows下MySQL主從復(fù)制的配置方法

    MySQL主從復(fù)制允許將來(lái)自一個(gè)數(shù)據(jù)庫(kù)(主數(shù)據(jù)庫(kù))的數(shù)據(jù)復(fù)制到一個(gè)或多個(gè)數(shù)據(jù)庫(kù)(從數(shù)據(jù)庫(kù)),主數(shù)據(jù)庫(kù)一般是實(shí)時(shí)的業(yè)務(wù)數(shù)據(jù)寫(xiě)入和更新操作,從數(shù)據(jù)庫(kù)常用的讀取為主
    2020-04-04
  • Mysql常用函數(shù)大全(分類(lèi)匯總講解)

    Mysql常用函數(shù)大全(分類(lèi)匯總講解)

    今天小編就為大家分享一篇關(guān)于Mysql常用函數(shù)大全(分類(lèi)匯總講解),小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-03-03

最新評(píng)論