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

Mysql中JSON字段的值的實(shí)現(xiàn)示例

 更新時(shí)間:2024年09月11日 09:20:56   作者:正常人誰(shuí)寫(xiě)代碼啊  
本文中介紹了如何通過(guò)SQL語(yǔ)句查詢(xún)JSON字段中的特定數(shù)據(jù),如查詢(xún)數(shù)組中的元素,提取映射中的值,以及使用不同的JSON函數(shù)來(lái)處理數(shù)據(jù),感興趣的可以了解一下

我們?cè)诓樵?xún)mysql數(shù)據(jù)時(shí),查詢(xún)某個(gè)字段的數(shù)劇是我們經(jīng)常接觸的,直接使用sql語(yǔ)句或者更方便的直接使用數(shù)據(jù)庫(kù)的orm語(yǔ)句查詢(xún)。但是如果需要查詢(xún)某個(gè)json字段里面的某些數(shù)據(jù),orm模型可能都無(wú)法達(dá)到效果,還不如直接使用sql語(yǔ)句進(jìn)行查詢(xún)來(lái)的直觀。下面總結(jié)了一些sql語(yǔ)句查詢(xún)json字段里面的值。

mysql版本是5.7,使用fastapi和tortoise-orm接口的方式返回查詢(xún)到的響應(yīng)結(jié)果。

下面創(chuàng)建了一個(gè)用于測(cè)試的數(shù)據(jù)表。包括主鍵id,varchar類(lèi)型的name,json類(lèi)型的code(數(shù)組)和info(映射)。

例如:code數(shù)據(jù)結(jié)構(gòu):["A1b2C3d4E5", "F6g7H8i9J0", "K1l2M3n4O5", "P6q7R8s9T0", "U1v2W3x4Y5", "Z6a7B8c9D0", "E1F2g3H4i5", "J6k7L8m9N0", "O1P2q3R4s5", "T6U7v8W9x0", "Y1Z2a3B4c5", "D6E7F8g9H0", "I1j2K3l4M5", "N6O7P8q9R0", "S1T2U3v4W5", "X6Y7Z8a9B0"]
info數(shù)據(jù)結(jié)構(gòu):{"age": 30, "city": "New York", "name": "Alice", "contact": {"email": "alice@example.com", "phone": "123-456-7890"}, "education": "Bachelor"}

85139ddd3d1542a9872f203a861a1dd5.png

 1、查詢(xún)info中age=30的數(shù)據(jù)

@router.get('/jsontest/{keyword}/{value}', description="獲取mysql的json值測(cè)試")
async def search_(keyword: str, value: str):
    query = f"SELECT * FROM jsontest WHERE JSON_CONTAINS(info->'$.{keyword}','{value}')"
    conn = tortoise.Tortoise.get_connection("default")
    try:
        _, index_result = await conn.execute_query(query)
    except Exception as ex:
        error_msg = f"error:{ex.__class__.__name__}-{str(ex)}"
        log_it(error_msg, level=logging.ERROR)
        return JSONResponse(status_code=status.HTTP_500_INTERNAL_SERVER_ERROR, content=error_msg)
    finally:
        await conn.close()
    return JSONResponse(
        status_code=status.HTTP_200_OK,
        content=index_result
    )
SELECT * FROM jsontest WHERE JSON_CONTAINS(info->'$.age','30')

查詢(xún)結(jié)果

cb7aa08af0d349f0b97519feff32ff03.png

 為了避免重復(fù)代碼冗余,后續(xù)的查詢(xún)直接寫(xiě)sql語(yǔ)句了??梢酝ㄟ^(guò)更改api接口傳參,構(gòu)造query語(yǔ)句達(dá)到一樣的效果。

2、查詢(xún)code數(shù)組中包含"ANOPQRSTU8"的數(shù)據(jù)

SELECT * FROM jsontest WHERE JSON_CONTAINS(code,'"ANOPQRSTU8"')

3、查詢(xún)info中city是New York并且code中包含AWXYZ01239的數(shù)據(jù)

SELECT * FROM jsontest WHERE JSON_CONTAINS(info->'$.city','"New York"') AND JSON_CONTAINS(code,'"AWXYZ01239"')

4、查詢(xún)info中包含city和age的數(shù)據(jù),指定的是"one"表示只需包含任何一個(gè)路徑即可,"all"表示需要包含所有指定路徑

SELECT * FROM jsontest WHERE JSON_CONTAINS_PATH(info, 'one', '$.city', '$.age');
SELECT * FROM jsontest WHERE JSON_CONTAINS_PATH(info, 'all', '$.city', '$.contact.email');

5、查詢(xún)Alice info數(shù)據(jù)中的city,age,以及contact里面的email。下面兩種效果是一樣的,只不過(guò)使用JSON_EXTRACT返回的是一個(gè)字段,而->這種方法返回的是拆分開(kāi)的字段

SELECT JSON_EXTRACT(info, '$.city','$.age','$.contact.email') AS name FROM jsontest WHERE name = 'Alice';
SELECT info->'$.city',info->'$.age',info->'$.contact.email' FROM jsontest WHERE name = 'Alice'

6、查詢(xún)Alice code數(shù)組中前三個(gè)數(shù)據(jù)。數(shù)組類(lèi)型的json只能通過(guò)索引獲取值,如果想獲取全部則改成'$[*]'即可。下面兩種效果是一樣的,只不過(guò)使用JSON_EXTRACT返回的是一個(gè)字段,而->這種方法返回的是拆分開(kāi)的字段

SELECT JSON_EXTRACT(code, '$[0]','$[1]','$[2]') AS res FROM jsontest WHERE name = 'Alice';
SELECT code->'$[0]',code->'$[1]',code->'$[2]' FROM jsontest WHERE name = 'Alice';
# 獲取數(shù)組里面的所有數(shù)據(jù)
SELECT JSON_EXTRACT(code, '$[*]') AS res FROM jsontest WHERE name = 'Alice';
SELECT code->'$[*]'  FROM jsontest WHERE name = 'Alice';

7、使用JSON_UNQUOTE去除 JSON 字符串的引號(hào)。上面返回的數(shù)據(jù)帶有原始json的引號(hào),這一點(diǎn)有時(shí)對(duì)結(jié)果處理特別不友好,可以使用JSON_UNQUOTE進(jìn)行處理

SELECT JSON_UNQUOTE(JSON_EXTRACT(info, '$.contact.email')) AS email FROM jsontest WHERE name = 'Alice';

8、提取info映射里面的所有key,也可以查詢(xún)嵌套字典里面的所有key

SELECT JSON_KEYS(info) AS k FROM jsontest WHERE name = 'Alice';
#查詢(xún)嵌套字典的key
SELECT JSON_KEYS(info->'$.contact') AS k FROM jsontest WHERE name = 'Alice';

9、獲取code數(shù)組和字典info的長(zhǎng)度

SELECT JSON_LENGTH(code, '$') as count  FROM jsontest WHERE name = 'Alice'
SELECT JSON_LENGTH(info, '$') as count  FROM jsontest WHERE name = 'Alice'
# 獲取嵌套字典的長(zhǎng)度
SELECT JSON_LENGTH(info->'$.contact') as count  FROM jsontest WHERE name = 'Alice'

10、搜索數(shù)組和字典里面的值

# 搜索字典中的value,one_or_all: 指定搜索所有匹配項(xiàng)還是僅找到的第一個(gè)匹配項(xiàng)
SELECT JSON_SEARCH(info, 'all', "New York") AS search_result FROM jsontest
# 搜索數(shù)組中的值,%A%模糊搜索含有A的數(shù)據(jù)
SELECT JSON_SEARCH(code, 'all', '%A%') AS search_result FROM jsontest

到此這篇關(guān)于Mysql中JSON字段的值的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)Mysql JSON字段值內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL中使用SQL語(yǔ)句查看某個(gè)表的編碼方法

    MySQL中使用SQL語(yǔ)句查看某個(gè)表的編碼方法

    下面小編就為大家?guī)?lái)一篇MySQL中使用SQL語(yǔ)句查看某個(gè)表的編碼方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-11-11
  • 如何在Windows中運(yùn)行多個(gè)MySQL實(shí)例詳解

    如何在Windows中運(yùn)行多個(gè)MySQL實(shí)例詳解

    這篇文章主要給大家介紹了關(guān)于如何在Windows中運(yùn)行多個(gè)MySQL實(shí)例的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • MySQL性能優(yōu)化神器Explain的基本使用分析

    MySQL性能優(yōu)化神器Explain的基本使用分析

    這篇文章主要給大家介紹了關(guān)于MySQL性能優(yōu)化神器Explain的基本使用分析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • centos編譯安裝mysql 5.6及安裝多個(gè)mysql實(shí)例詳解

    centos編譯安裝mysql 5.6及安裝多個(gè)mysql實(shí)例詳解

    這篇文章主要介紹了centos編譯安裝mysql 5.6及安裝多個(gè)mysql實(shí)例詳解,需要的朋友可以參考下
    2017-02-02
  • SQL基礎(chǔ)的查詢(xún)語(yǔ)句

    SQL基礎(chǔ)的查詢(xún)語(yǔ)句

    這篇文章主要給大家分享的是SQL基礎(chǔ)的查詢(xún)語(yǔ)句,SQL語(yǔ)句中,查詢(xún)是使用最多的操作,SQL不僅能夠查詢(xún)表中的數(shù)據(jù),還可以返回算術(shù)運(yùn)算、表達(dá)式的結(jié)果等,接下來(lái)就一起了解一下基本的查詢(xún)語(yǔ)句,需要的朋友可以參考一下
    2021-11-11
  • insert into … on duplicate key update / replace into 多行數(shù)據(jù)介紹

    insert into … on duplicate key update / replace into 多行數(shù)據(jù)介紹

    當(dāng)我插入一條數(shù)據(jù)時(shí),我要判斷(k1,k2)是否已經(jīng)存在(1條selete),若存在就update,不存在就insert
    2013-08-08
  • Mysql SSH隧道連接使用的基本步驟

    Mysql SSH隧道連接使用的基本步驟

    這篇文章主要給大家介紹了關(guān)于Mysql SSH隧道連接使用的基本步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Mysql具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • MySQL入門(mén)教程(七)之視圖

    MySQL入門(mén)教程(七)之視圖

    視圖是從一個(gè)或多個(gè)表中導(dǎo)出來(lái)的虛擬表。視圖就像一個(gè)窗口,通過(guò)這個(gè)窗口可以看到系統(tǒng)專(zhuān)門(mén)提供的數(shù)據(jù)。本文給大家介紹MySQL入門(mén)教程(七)之視圖,需要的朋友參考下
    2016-04-04
  • 史上最簡(jiǎn)單的MySQL數(shù)據(jù)備份與還原教程(中)(三十六)

    史上最簡(jiǎn)單的MySQL數(shù)據(jù)備份與還原教程(中)(三十六)

    這篇文章主要為大家詳細(xì)介紹了史上最簡(jiǎn)單的MySQL數(shù)據(jù)備份與還原教程中篇,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • mysql表的清空、刪除和修改操作詳解

    mysql表的清空、刪除和修改操作詳解

    這篇文章主要詳細(xì)介紹了mysql表的清空、刪除和修改操作的方法,以及一些常用的mysql的常用操作,非常的簡(jiǎn)單實(shí)用,有需要的可以參考下
    2014-09-09

最新評(píng)論