MySQL 中的 JSON_CONTAINS 函数详解

这篇具有很好参考价值的文章主要介绍了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 数据。希望本文能帮助你更好地理解和使用这个函数。文章来源地址https://www.toymoban.com/news/detail-772698.html

到了这里,关于MySQL 中的 JSON_CONTAINS 函数详解的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • MySQL数据库基础:JSON函数各类操作一文详解

    很多日常业务场景都会用到json文件作为数据存储起来,而mysql5.7以上就提供了存储json的支撑。往常存储json一般都保留在pg库或者是hive库里面,现在mysql有了支持的话基本业务都可以用mysql来实现。现在mysql8.x版本对json字符出处理已经做的非常完善了。现在就让我们来详细了解

    2024年02月04日
    浏览(53)
  • Mysql中的 IFNULL 函数的详解

    目录 一、概念 二、语法 三、Demo 举例说明 创建表 加入数据 运行结果 3.1举例一 3.2举例二 3.3举例三 3.4举例四 注意事项 在mysql中IFNULL() 函数用于判断第一个表达式是否为 NULL,如果第一个值不为NULL就执行第一个值。第一个值为 NULL 则返回第二个参数的值。 使用技巧见: 3.2举

    2024年02月16日
    浏览(64)
  • Mysql中的find_in_set() 函数用法详解及使用场景

    一、find_in_set() 函数详解 示例: 相信大家看完以上示例就知道这个函数的大概作用了,以下是MySQL手册中官方说明 概括一下就是(前一个字符串是A,后一个字符串是B): 如果B字符串包含A字符串:则返回大于0的值,这个值就是A字符串在B字符串的所在位置; 如果B字符串不

    2024年02月13日
    浏览(42)
  • MySQL JSON_TABLE() 函数

    介绍:JSON_TABLE()函数从一个指定的JSON文档中提取数据并返回一个具有指定列的关系表。 应用:数据库字段以JSON 存储后,实际应用需要对其中一个字段进行查询 语法:JSON_TABLE(json,path COLUMNS(column[,column[,...]]))column:name 实例: 数组分别取值 JSON 数组中有两个对象。 路径表达式

    2024年02月13日
    浏览(71)
  • 【MySQL】MySQL 8 的 JSON 新特性详解(1)JSON 数据类型

    你好,我是小雨青年,一名使用MySQL 8 的程序员。 MySQL 8 引入了对 JSON 数据类型的全面支持,并提供了一组内置函数以有效处理 JSON 数据。MySQL 8 中的 JSON 支持的一些关键特性如下: JSON 数据类型:MySQL 8 拥有一个名为 JSON 的新数据类型,可用于在列中存储 JSON 数据。该数据类

    2024年02月02日
    浏览(43)
  • MySQL中JSON数据类型详解

    目录 概要及优点 JSON定义 JSON字段的增删改查操作 插入操作 查询操作 修改操作 删除操作 如何对JSON字段创建索引?  加索引查询结果分析:  不加索引查询结果分析: 使用JSON时的注意事项         JSON数据类型是MySQL5.7.8开始支持的。在此之前,只能通过字符类型(CHAR、V

    2024年02月06日
    浏览(79)
  • MySQL的Json类型个人用法详解

    前言 虽然MySQL很早就添加了Json类型,但是在业务开发过程中还是很少设计带这种类型的表。少不代表没有,当真正要对Json类型进行特定查询,修改,插入和优化等操作时,却感觉一下子想不起那些函数怎么使用。比如把json里的某个键和值作为SQL条件,修改某个键下的子键的

    2024年02月10日
    浏览(36)
  • 解锁Mysql中的JSON数据类型,怎一个爽字了得

    在实际业务开发中,随着业务的变化,数据的复杂性和多样性不断增加。传统的关系型数据库模型在这种情况下会显得受限,因为它们需要预先定义严格的数据模式,并且通常只能存储具有相同结构的数据。而面对非结构化或半结构化数据的存储和处理需求,选择使用非关系

    2024年02月20日
    浏览(42)
  • [MySQL] MySQL中的内置函数

      本篇文章主要是对MySQL中常见的内置函数进行了详细解释。例如有日期类函数、字符串类函数、数学类函数等等。希望本篇文章会对你有所帮助。  文章目录 一、日期类函数 1、1 使用详解 1、2 实例演示 二、字符串函数 2、1 使用详解 2、2 实例演示 三、数学函数 四、其他函

    2024年02月04日
    浏览(41)
  • MySQL中的DATEDIFF()函数

    1.基本信息 在MySQL中, DATEDIFF 是一个日期函数,用于计算两个日期之间的差距,并以指定的时间单位返回结果。其函数形式如下列代码块所示: 注意:在MySQL中,DATEDIFF有且仅有两个参数,那就是结束时间和开始时间,不存在第一个参数为day,year这种的,那不是MySQL中的DATE

    2024年02月06日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包