Mysql内储存JSON字符串根据条件进行查询

MySQL中可以使用JSON值类型存储JSON格式的数据。而且MySQL也提供了一系列的JSON函数和操作符来方便地处理JSON值类型的数据。以下是使用MySQL内储存JSON字符串根据条件进行查询的步骤和实例说明。

步骤

  1. 创建一个表格

在MySQL数据库中,我们可以用如下语句创建一个表格:

sql
CREATE TABLE `students` (
`id` INT(10) unsigned NOT NULL AUTO_INCREMENT,
`name` VARCHAR(255) NOT NULL,
`age` INT(10) unsigned NOT NULL,
`info` JSON NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4

这个表格包含4个字段,其中info是JSON类型字段。

  1. 插入数据

在表格中插入一些数据(以下示例数据仅供演示使用):

sql
INSERT INTO `students` (`name`, `age`, `info`)
VALUES
('John', 20, '{"address": "New York", "courses": ["Math", "English"]}' ),
('Tom', 18, '{"address": "Los Angeles", "courses": ["Computer Science", "Chemistry", "Geography"]}' ),
('Lucy', 21, '{"address": "San Francisco", "courses": ["Physics", "History"]}' );

注意:JSON值要用双引号括起来。

  1. 查询数据

查询JSON字段的数据使用->操作符和->>操作符。

  • ->:返回一个JSON对象或一个JSON数组中指定元素的数值
  • ->>:返回一个JSON对象或一个JSON数组中指定元素的文本值

以下是一些示例代码:

  1. 查询address为"New York"的学生信息:

    sql
    SELECT * FROM `students` WHERE `info` ->> '$.address' = 'New York';

    上述代码中,->>把JSON对象中的"address"字段返回为一个文本值,'$'表示根节点。

  2. 查询所有修习了"Math"课程的学生信息:

    sql
    SELECT * FROM `students` WHERE `info` -> '$.courses' LIKE '%Math%';

    上述代码用LIKE操作符查询"Math"是否出现在JSON数组中的"courses"字段里。

示例说明

上述代码的运行结果:

id name age info
1 John 20 {"address": "New York", "courses": ["Math", "English"]}
id name age info
2 Tom 18 {"address": "Los Angeles", "courses": ["Computer Science", "Chemistry", "Geography"]}

第一个结果中的info字段中有"address": "New York""courses": ["Math", "English"]两个属性。而第二个结果中的info字段中有"address": "Los Angeles""courses": ["Computer Science", "Chemistry", "Geography"],但因为其"courses"属性中没有"Math",所以没有被查询出来。

第二个示例中的运行结果:

id name age info
1 John 20 {"address": "New York", "courses": ["Math", "English"]}

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Mysql内储存JSON字符串根据条件进行查询 - Python技术站

(0)
上一篇 2023年6月11日
下一篇 2023年6月11日

相关文章

  • javascript 封装Date日期类实例详解

    Javascript 封装 Date 日期类实例详解 在 Javascript 中,Date 类是表示日期和时间的对象,Date 有多种构造函数和方法,可以根据需求获取、设置日期或时间,也可以将日期对象转换为字符串。 创建 Date 对象 可以使用 new Date() 构造函数创建 Date 对象,如果没有传递参数,则创建当前日期和时间的 Date 对象。…

    JavaScript 2023年6月10日
    00
  • js实现多个倒计时并行 js拼团倒计时

    实现多个倒计时并行的方式如下: 使用 Date 对象获取当前时间和目标时间之间的时间差,然后根据时间差计算出剩余时间。 将剩余时间转换成分、秒和毫秒,然后在网页上显示出来,使用定时器每隔一秒更新一次显示的时间。 判断剩余时间是否为零,如果为零则停止定时器,显示倒计时结束提示。 代码示例: // 倒计时的目标时间(2019年12月31日 23:59:59) v…

    JavaScript 2023年6月10日
    00
  • javascript下判断一个对象是否具有指定名称的属性的的代码

    要判断一个 JavaScript 对象是否具有指定名称的属性,可以使用 in 或者 hasOwnProperty() 方法。 使用 in 关键字进行属性判断 in 关键字可以用于判断一个对象是否具有指定名称的属性,返回布尔值 true 或 false。 const person = { name: ‘张三’, age: 20 }; // 判断对象是否具有指定…

    JavaScript 2023年5月27日
    00
  • JS中正则表达式要注意lastIndex属性

    JavaScript中的正则表达式是一种特殊的对象类型,用来匹配字符串中的模式。在正则表达式匹配时,需要注意到lastIndex属性。 lastIndex属性介绍 lastIndex是RegExp对象的一个属性,表示正则表达式匹配下一个字符的位置。当进行全局匹配时,每次匹配都是从上一次匹配完成后lastIndex处继续查找。当进行非全局匹配时,lastInd…

    JavaScript 2023年6月10日
    00
  • JavaScript 用fetch 实现异步下载文件功能

    下面是实现JavaScript使用fetch实现异步下载文件功能的完整攻略。 1. 前置知识 在开始操作之前,需要对以下概念有一定的了解: JavaScript fetch API Blob URL.createObjectURL() a标签的download属性 2. 原理分析 JavaScript的fetch API可以向服务器请求获取数据或者资源并进行…

    JavaScript 2023年5月27日
    00
  • Python中还原JavaScript的escape函数编码后字符串的方法

    下面是详细讲解 Python 中还原 JavaScript 的 escape 函数编码后字符串的方法的完整攻略: 1. 什么是 JavaScript 的 escape 函数? JavaScript 的 escape 函数是一种将字符串编码成可在 URL 中传输的形式的方法。该函数可以用来防止 URL 路径中出现非法字符或中文字符时乱码。它会将非 ASCII …

    JavaScript 2023年5月19日
    00
  • Jquery Ajax学习实例5 向WebService发出请求,返回泛型集合数据的异步调用

    一、什么是jQuery Ajax? jQuery Ajax是一组用于处理Ajax请求的方法和函数。通过它可以实现异步获取数据和处理数据的功能,可以向服务器发送请求以及在不刷新页面的情况下接收来自服务器的响应数据,从而实现网页动态更新的效果。 二、向WebService发出请求,返回泛型集合数据的异步调用 在使用jQuery Ajax与Web Service交…

    JavaScript 2023年6月11日
    00
  • JavaScript实现栈结构详细过程

    以下是JavaScript实现栈结构的详细攻略: 什么是栈结构? 栈是一种线性数据结构,具有先进后出的特点,也就是最后压入栈中的数据最先弹出。栈的操作主要包括入栈(push)、出栈(pop)和查看栈顶元素(peek)。 JavaScript实现栈结构的详细过程 1.使用数组来实现栈结构 我们可以使用JavaScript中的Array来实现栈结构,Array的…

    JavaScript 2023年5月28日
    00
合作推广
合作推广
分享本页
返回顶部