MySQL查询JSON数组字段包含特定字符串的方法

2025-06-30 17:50

本文主要是介绍MySQL查询JSON数组字段包含特定字符串的方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种...

问题背景

mysql数据库中,当某个字段存储的是jsON数组(如["喷绘","2.6m喷绘","M喷绘","直喷","双透","气模"]),需要查询数组中包含特定字符串(如’气模’)的记录时,传统的LIKE语句无法直接使用。本文介绍两种高效的解决方案。

解决方案对比

1. 精确匹配方案(推荐)

当需要完全匹配数组中的元素时(如精确查找"气模"):

SELECT *
FROM process_unit_prices
WHERE 
  process_name = '制图' 
  AND JSON_CONTAINS(craft_name, JSON_QUOTE('气模'))
LIMIT 1;

1.核心函数

  • JSON_QUOTE(): 将字符串转为JSON格式(如"气模"
  • JSON_CONTAINS(): 检查JSON数组中是否包含指定值

2.优点:效率高,精确匹配数组元素

3.注意:必须元素完全相等才会匹配(如"气模车"不会匹配)

2. 模糊匹配方案

当需要部分匹配元素内容时(如查找包含"气模"子串的元素):

SELECT *
FROM process_unit_prices
WHERE 
  process_name = '制图' 
  AND JSON_SEARCH(craft_name, 'one', '%气模%') IS NOT NULL
LIMIT 1;

1.核心函数

  • JSON_SEARCH(): 搜索JSON中匹配模式的路径
  • 'one': 找到第一个匹配即停止
  • '%气模%': SQL的LIKE通配符模式

2.优点:支持模糊匹配

3.注意:效率低于精确匹配,大数据量时需谨慎

参数化查询示例

在MyBATis等ORM框架中使用(如Spring Boot项目):

<!-- 精确匹配 -->
<select id="findProcess" resultType="Proceswww.chinasem.cnsPrice">
  SELECT * FROM process_unit_prices
  WHERE process_name = #{processType}
    AND JSON_CONTAINS(craft_name, JSON_QUOTE(#{craft}))
  LIMIT 1
</select>

<!-- 模糊匹配 -->
<select id="findProcessFuzzy" resultType="ProcessPrice">
  SELECT * FROM process_unit_prices
  WHERE process_name = #{processType}
    AND JSON_SEARCH(craft_name, 'one', CONCAT('%', #{craft}, '%')) IS NOT NULL
  LIMIT 1
</select&China编程gt;

使用场景建议

场景推荐方案示例
分类标签匹配精确匹配工艺类型=[“雕刻”,“喷涂”]
关键字搜索模糊匹配描述包含"紧急"的订单
多值属性过滤精确匹配颜色=[“红”,“蓝”]

性能优化贴士

索引优化:MySQL 8.0+可为JSON字段创建函数索引

CREATE INDEX idx_craft ON process_unit_prices((CAST(craft_name AS CHAR(255))));

数据规范:若常需查询,建议拆分为关系表

避免全模糊%气模%无法使用索引,尽量用气模%

经验总结:JSON字段查询虽灵活,但需谨慎使用。精确匹配首选JSON_CONTAINS,模糊需求再用JSON_SEARCH,并注意性能影响。在数据设计阶段评估是否真需JSON结构,关系表通常更高效。

知识扩展

下面小编为大家整理了MYSQL 匹配查询JSON字段的相关方法,希望对大家有所帮助

在 MySQL 中,如果你存储的是 JSON 数据,并且需要检查某个 JSON 字段是否包含一个特定的键值对(例如 {user1: 1}),你可以使用 MySQL 提供的 JSON 函数来实现。

1. 使用 JSON_CONTAINS() 函数

JSON_CONTAINS() 函数可以检查一个 JSON 字段是否包含另一个 JSON 值。该函数返回一个布尔值,如果第一个参数(JSON 数据)包含第二个参数(查询条件),则返回 1,否则返回 0

示例查询:

假设你的表结构如下:

CREATE TABLE users (
    id INT AUTO_INCREMENT PRIMARY KEY,
    user_data JSON
);

你可以通过 JSON_CONTAINS() 函数来检查 JSON 字段是否包含 {user1: 1}

SEL编程China编程ECT * 
FROM users 
WHERE JSON_CONTAINS(user_data, '{"user1": 1}');

这条 SQL 语句会返回所有 user_data 字段包含 {user1: 1} 键值对的记录。

2. JSON_CONTAINS() 函数的使用细节

  • 第一个参数是你要查询的 JSON 字段。
  • 第二个参数是你要查找的 JSON 数据,必须是一个有效的 JSON 格式字符串。
  • 该函数会检查 JSON 字段中是否存在第二个参数所表示的键值对。

3. 查询部分匹配

如果你只想检查 JSON 字段中是否存在某个键(例如 user1)并且该键的值是 1,而不关心 JSON 字段中的其他内容,你仍然可以使用 JSON_CONTAINS(),但是需要确保第二个参数符合你想要的结构。

SELECT javascript* 
FROM users 
WHERE JSON_CONTAINS(user_data, '{"user1": 1}');

4. 检查 JSON 字段中是否包含某个键

如果你不关心键值对,只想检查 JSON 字段中是否包含某个键(比如 user1),可以使用 JSON_EXTRACT() 或 JSON_UNQUOTE() 与 IS NOT NULL 来实现。

SELECT * 
FROM users 
WHERE JSON_UNQUOTE(JSON_EXTRACT(user_d编程ata, '$.user1')) = '1';
  • JSON_EXTRACT(user_data, '$.user1') 提取 user_data 字段中的 user1 键的值。
  • JSON_UNQUOTE() 去除引号,使其返回一个普通值。
  • 比较提取的值是否等于 '1'

小结

  • JSON_CONTAINS():用于检查 JSON 字段是否包含某个指定的键值对。
  • JSON_EXTRACT() + JSON_UNQUOTE():可以用来提取并比较 JSON 字段中的值。

使用 JSON_CONTAINS() 是检查 JSON 数据是否包含某个完整键值对的简便方法。如果你需要更细粒度的查询(如只关心键是否存在且其值为特定值),可以结合 JSON_EXTRACT() 和 JSON_UNQUOTE() 进行操作。

到此这篇关于MySQL查询JSON数组字段包含特定字符串的方法的文章就介绍到这了,更多相关MySQL查询JSON字段内容请搜索China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持China编程(www.chinasem.cn)!

这篇关于MySQL查询JSON数组字段包含特定字符串的方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1155264

相关文章

检查 Nginx 是否启动的几种方法

《检查Nginx是否启动的几种方法》本文主要介绍了检查Nginx是否启动的几种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1. 使用 systemctl 命令(推荐)2. 使用 service 命令3. 检查进程是否存在4

Java方法重载与重写之同名方法的双面魔法(最新整理)

《Java方法重载与重写之同名方法的双面魔法(最新整理)》文章介绍了Java中的方法重载Overloading和方法重写Overriding的区别联系,方法重载是指在同一个类中,允许存在多个方法名相同... 目录Java方法重载与重写:同名方法的双面魔法方法重载(Overloading):同门师兄弟的不同绝

MySQL字符串转数值的方法全解析

《MySQL字符串转数值的方法全解析》在MySQL开发中,字符串与数值的转换是高频操作,本文从隐式转换原理、显式转换方法、典型场景案例、风险防控四个维度系统梳理,助您精准掌握这一核心技能,需要的朋友可... 目录一、隐式转换:自动但需警惕的&ld编程quo;双刃剑”二、显式转换:三大核心方法详解三、典型场景

MySQL中between and的基本用法、范围查询示例详解

《MySQL中betweenand的基本用法、范围查询示例详解》BETWEENAND操作符在MySQL中用于选择在两个值之间的数据,包括边界值,它支持数值和日期类型,示例展示了如何使用BETWEEN... 目录一、between and语法二、使用示例2.1、betwphpeen and数值查询2.2、be

Java数组动态扩容的实现示例

《Java数组动态扩容的实现示例》本文主要介绍了Java数组动态扩容的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1 问题2 方法3 结语1 问题实现动态的给数组添加元素效果,实现对数组扩容,原始数组使用静态分配

MySQL快速复制一张表的四种核心方法(包括表结构和数据)

《MySQL快速复制一张表的四种核心方法(包括表结构和数据)》本文详细介绍了四种复制MySQL表(结构+数据)的方法,并对每种方法进行了对比分析,适用于不同场景和数据量的复制需求,特别是针对超大表(1... 目录一、mysql 复制表(结构+数据)的 4 种核心方法(面试结构化回答)方法 1:CREATE

详解C++ 存储二进制数据容器的几种方法

《详解C++存储二进制数据容器的几种方法》本文主要介绍了详解C++存储二进制数据容器,包括std::vector、std::array、std::string、std::bitset和std::ve... 目录1.std::vector<uint8_t>(最常用)特点:适用场景:示例:2.std::arra

springboot中配置logback-spring.xml的方法

《springboot中配置logback-spring.xml的方法》文章介绍了如何在SpringBoot项目中配置logback-spring.xml文件来进行日志管理,包括如何定义日志输出方式、... 目录一、在src/main/resources目录下,也就是在classpath路径下创建logba

SQL Server中行转列方法详细讲解

《SQLServer中行转列方法详细讲解》SQL行转列、列转行可以帮助我们更方便地处理数据,生成需要的报表和结果集,:本文主要介绍SQLServer中行转列方法的相关资料,需要的朋友可以参考下... 目录前言一、为什么需要行转列二、行转列的基本概念三、使用PIVOT运算符进行行转列1.创建示例数据表并插入数

C++打印 vector的几种方法小结

《C++打印vector的几种方法小结》本文介绍了C++中遍历vector的几种方法,包括使用迭代器、auto关键字、typedef、计数器以及C++11引入的范围基础循环,具有一定的参考价值,感兴... 目录1. 使用迭代器2. 使用 auto (C++11) / typedef / type alias