MySQL 中的 JSON_CONTAINS 函數詳解

在處理 MySQL 中的 JSON 數據時,我們經常需要檢查一個 JSON 文檔是否包含特定的值。這時,JSON_CONTAINS 函數就顯得非常有用。

JSON_CONTAINS函數介紹

JSON_CONTAINS 是 MySQL 提供的一個 JSON 函數,用于測試一個 JSON 文檔是否包含特定的值。如果包含則返回 1,否則返回 0。該函數接受三個參數:

  1. target: 待搜索的目標 JSON 文檔。
  2. candidate: 在目標 JSON 文檔中要搜索的值。
  3. path(可選): 路徑表達式,指示在哪里搜索候選值。

一般的使用語法為:

JSON_CONTAINS(target, candidate[, path])

JSON_CONTAINS函數實例演示

假設我們有一個名為 products 的表,其中包含了一些產品信息:

CREATE TABLE products (id INT AUTO_INCREMENT PRIMARY KEY,details JSON
);INSERT INTO products (details)
VALUES 
('{"name": "Product 1", "tags": ["tag1", "tag2", "tag3"]}'),
('{"name": "Product 2", "tags": ["tag1", "tag4"]}');

現在,我們想要找出所有包含 "tag1" 標簽的產品。我們可以利用 JSON_CONTAINS 函數來實現這個需求:

SELECT * FROM products WHERE JSON_CONTAINS(details->'$.tags', '"tag1"');

JSON_CONTAINS函數的路徑參數

JSON_CONTAINS 函數提供了一個可選的 path 參數,用于指定應在 JSON 文檔的哪個部分搜索候選值。這個參數的值應該是一個 JSON 路徑表達式。

SELECT * FROM products WHERE JSON_CONTAINS(details, '"red"', '$.metadata.color');

在這條查詢中,$.metadata.color 是路徑表達式,表示我們要在 details JSON 文檔的 metadata.color 段中搜索 "red" 值。

JSON_CONTAINS函數的兩種使用方式比較

雖然 JSON_CONTAINS(details, '"red"', '$.metadata.color')JSON_CONTAINS(details->'$.metadata.color', '"red"') 在大多數情況下的結果是相同的,但是它們在某些特殊場景下的處理策略是有區別的。

  1. details->'$.metadata.color' 這種寫法先從 details 字段的 metadata.color 部分取出值,然后以此為基礎進行 JSON_CONTAINS 操作。如果你想在獲取的 JSON 片段上進行進一步的操作,這種方式會更方便。

  2. JSON_CONTAINS(details, '"red"', '$.metadata.color') 直接在 details 字段中執行了 JSON_CONTAINS,在查找過程中指定了路徑。它是一個單獨的表達式,不能直接用于進一步提取或操作 JSON 數據。但如果你只是簡單地檢查指定路徑下是否包含特定值,那么這種方法就足夠了。

實際使用哪種方式,取決于你的具體需求和場景。

總的來說,JSON_CONTAINS 是一個功能強大的函數,使我們能夠以靈活、高效的方式在 MySQL 中處理 JSON 數據。希望本文能幫助你更好地理解和使用這個函數。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/167974.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/167974.shtml
英文地址,請注明出處:http://en.pswp.cn/news/167974.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

SQLite 和 SQLiteDatabase 的使用

實驗七:SQLite 和 SQLiteDatabase 的使用 7.1 實驗目的 本次實驗的目的是讓大家熟悉 Android 中對數據庫進行操作的相關的接口、類等。SQLiteDatabase 這個是在 android 中數據庫操作使用最頻繁的一個類。通過它可以實現數據庫的創建或打開、創建表、插入數據、刪…

22、什么是中間件和權限攔截中間件實操

新建中間件 middleware\auth.js // 定義權限判斷中間件,中間件的第一個參數是context export default ({store, redirect}) > {console.log("中間件被調用")// if (!store || !store.state.userinfo) {// redirect("/")// } }頁面使用…

CF -- Educational Codeforces Round 158 (Rated for Div. 2) -- D 補題記錄

Yet Another Monster Fight Problem - D - Codeforces 題目大意: 現在給你一堆怪物,你擁有法術(一個法術可以連續攻擊這n個所有怪物),你可以選擇任意一個怪物作為法術的第一個攻擊目標(傷害為x&#xff…

【MySQL】索引與事務

👑專欄內容:MySQL?個人主頁:子夜的星的主頁💕座右銘:前路未遠,步履不停 目錄 一、索引1、使用場景2、使用索引創建索引查看索引刪除索引 3、底層數據結構(非常重要) 二、事務1、概念…

Android設計模式--享元模式

水不激不躍,人不激不奮 一,定義 使用共享對象可有效地支持大量的細粒度的對象 享元模式是對象池的一種實現,用來盡可能減少內存使用量,它適合用于可能存在大量重復對象的場景,來緩存可共享的對象,達到對象…

騰訊云CVM標準型SA5云服務器AMD EPYC Bergamo處理器

騰訊云服務器標準型SA5實例是最新一代的標準型實例,CPU采用AMD EPYC? Bergamo全新處理器,采用最新DDR5內存,默認網絡優化,最高內網收發能力達4500萬pps。騰訊云百科txybk.com分享騰訊云標準型SA5云服務器CPU、內存、網絡、性能、…

Qt項目打包發布超詳細教程

https://blog.csdn.net/qq_45491628/article/details/129091320

用蘋果簽名免費獲取Xcode

使用蘋果企業簽名免費獲取Xcode: 打開Xcode。連接iOS設備到Mac。選擇Window→Devices and Simulators。選擇該設備。將IPA文件拖到“Installed Apps”的列表框中即可安裝。使用Cydia Impactor(可以在網上找到相關下載鏈接): 打開…

HTML網站穩定性狀態監控平臺源碼

這是一款網站穩定性狀態監控平臺源碼,它基于UptimeRobot接口進行開發。當您的網站遇到故障時,該平臺能夠通過郵件或短信通知您。下面是對安裝過程的詳細說明: 安裝步驟 將源碼上傳至您的主機或服務器,并進行解壓操作。 在Uptim…

自動化測試中幾種常見驗證碼的處理方式及如何實現?

UI自動化測試時,需要對驗證碼進行識別處理,有很多方式,每種方式都有自己的特點,以下是一些常用處理方法,僅供參考。 1 去掉驗證碼 從自動化的本質上來講,主要是提升測試效率等,但是為了去研究驗…

【點云surface】 修剪B樣條曲線擬合

1 介紹 Fitting trimmed B-splines(修剪B樣條曲線擬合)是一種用于對給定的點云數據進行曲線擬合的算法。該算法使用B樣條曲線模型來逼近給定的點云數據,并通過對模型進行修剪來提高擬合的精度和準確性。 B樣條曲線是一種常用的曲線表示方法…

【element優化經驗】el-dialog修改title樣式

目錄 前言 解決之路 1.把默認的這個圖標隱藏,官方的api有這個屬性:showClose值設置false. 2.title插槽定制:左邊定制標題,右邊定制按鈕區域。 3.背景顏色修改:默認title是有padding的需要把它重寫調,然…

基于卷積神經網絡CNN開發構建HAR人類行為識別Human Activity Recognition【完整代碼實踐】

行為識別相關的開發實踐在我們之前的博文中也有過相關的實踐了,感興趣的話可以自行移步閱讀即可:《python實現基于TNDADATASET的人體行為識別》 《UCI行為識別——Activity recognition with healthy older people using a batteryless wearable sensor Data Set》《人體行為…

基于 STM32Cube.AI 的嵌入式人臉識別算法實現

本文介紹了如何使用 STM32Cube.AI 工具開發嵌入式人臉識別算法。首先,我們將簡要介紹 STM32Cube.AI 工具和 STM32F系列單片機的特點。接下來,我們將詳細討論如何使用 STM32Cube.AI 工具鏈和相關庫來進行人臉識別算法的開發和優化。最后,我們提…

Netty實現websocket且實現url傳參的兩種方式(源碼分析)

1、先構建基本的netty框架 再下面的代碼中我構建了一個最基本的netty實現websocket的框架,其他個性化部分再自行添加。 Slf4j public class TeacherServer {public void teacherStart(int port) throws InterruptedException {NioEventLoopGroup boss new NioEve…

Day40力扣打卡

打卡記錄 包子湊數(裴蜀定理 DP) 根據裴蜀定理,存在 c gcd(a, b) 使不定方程ax by c滿足條件,如果gcd(a, b) 1即a與b互素的情況下,就會 ax by 1,由于為1可以構造后面的無窮數字,故得到結…

Centos7 離線安裝 CDH7.1.7

1. 安裝CDH的準備工作(所有節點都要執行) 1.1 準備環境 角色 IP k8s-master 192.168.181.129 k8s-node1 192.168.181.130 k8s-node2 192.168.181.131 1.2 安裝JDK # https://www.oracle.com/java/technologies/downloads/#java11 wget rpm -ivh…

亞馬遜Listing怎么寫!親身經驗分享

亞馬遜運營的重要環節之一,listing的攥寫,可以決定了產品的搜索排名,用戶的點擊率和轉化率,那么如果你的產品排名或者轉化不理想的情況,可以考慮對listing進行優化,在關鍵詞過多和語句流程通順的情況下&…

js獲取時間日期

目錄 Date 對象 1. 獲取當前時間 2. 獲取特定日期時間 Date 對象的方法 1. 獲取各種日期時間組件 2. 獲取星期幾 3. 獲取時間戳 格式化日期時間 1. 使用 toLocaleString() 方法 2. 使用第三方庫 UNIX 時間戳 內部表示 時區 Date 對象 JavaScript中內置的 Date 對象…

數據挖掘之PCA-主成分分析

PCA的用處:找出反應數據中最大變差的投影(就是拉的最開)。 在減少需要分析的指標同時,盡量減少原指標包含信息的損失,以達到對所收集數據進行全面分析的目的 但是什么時候信息保留的最多呢?具體一點&#…