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日

相关文章

  • vue使用GraphVis开发无限拓展的关系图谱的实现

    Vue使用GraphVis开发无限拓展的关系图谱的实现 简介 GraphVis是一款基于JavaScript的网络可视化库,它支持将任何TCP/IP网络视为节点和边的集合,还支持关系网和流程图的绘制。在Vue项目中使用GraphVis可以方便地展示关系图谱,并且可以轻松实现拓展。 实现过程 步骤一:安装GraphVis库 可以使用npm命令来安装GraphV…

    JavaScript 2023年6月11日
    00
  • JQuery在页面中添加和除移DOM示例代码

    JQuery是一个Javascript库,它提供了一些易于使用的方法,用于操作HTML页面元素以及与服务器进行异步通信。在JQuery中,我们可以轻松地通过添加DOM元素来更新页面。下面是添加和除移DOM元素的详细攻略: 添加DOM元素 可以使用以下JQuery方法来添加DOM元素: append() 使用append()方法向指定元素的最后一个子元素添加新…

    JavaScript 2023年6月10日
    00
  • JS URL传中文参数引发的乱码问题

    当JS程序需要将中文参数作为URL请求的一部分时,往往会引发“乱码”的问题。 造成该问题的原因是:URL中只能包含某些预定义的字符,例如字母、数字和少数几个符号。如果我们需要处理的中文字符没有被编码成它们应该代表的URL编码序列,那么这些字符就可能不能被正确地识别和使用。 接下来,我们将提供两种针对此问题的攻略: 攻略1:使用encodeURI和decode…

    JavaScript 2023年5月20日
    00
  • 一实用的实现table排序的Javascript类库

    我们来讲解一下如何实现table排序的Javascript类库。 概述 在网页中经常会用到表格(table),而对于一大堆数据,我们需要以某种特定的方式来进行排序,这时候就需要一个table排序的Javascript类库。下面,我们将通过一个简单的示例来讲解如何使用该类库实现排序功能。 准备工作 我们需要在HTML页面中引入jQuery框架以及js库文件so…

    JavaScript 2023年6月10日
    00
  • js获取单元格自定义属性值的代码(IE/Firefox)

    获取单元格自定义属性值的代码需要用到JavaScript的DOM操作,具体步骤如下: 获取单元格元素 首先,我们需要获取单元格元素,可以使用document.getElementById()方法获取单元格的ID,也可以使用document.getElementsByTagName()方法获取所有单元格元素并使用索引访问特定单元格。示例代码如下: var ce…

    JavaScript 2023年6月10日
    00
  • javascript的函数、创建对象、封装、属性和方法、继承

    下面我将详细讲解JavaScript中函数、创建对象、封装、属性和方法、继承的完整攻略,并且会给出至少两个示例。 函数 函数的定义 函数是一段被封装起来的可复用代码块。在 JavaScript 中,函数可以通过 function 关键字来定义。函数定义的一般语法格式为: function functionName(param1, param2, …){ …

    JavaScript 2023年5月27日
    00
  • JS实现网页抢购功能(触发,终止脚本)

    JS实现网页抢购功能可以基于浏览器的自动化工具,如selenium或者puppeteer,完成批量请求或模拟用户行为。在实现过程中,需要明确以下几个步骤: 登录并保持会话:在许多电商网站中,进行抢购之前首先需要登录账户。可以通过模拟登录的方式,实现自动输入账号密码并完成登录。在登录完成之后,需要保持会话以便于提交订单等后续的操作。 找到目标商品页面:一般情况…

    JavaScript 2023年6月10日
    00
  • JavaScript判断数组成员的几种方法

    下面是“JavaScript判断数组成员的几种方法”的完整攻略。 判断数组成员的几种方法 使用 JavaScript 判断一个变量是否为数组是非常重要的操作。下面介绍几种判断数组成员的方法。 1. instanceof 使用 instanceof 运算符可以判断一个变量是否为某个类的实例。因为在 JavaScript 中,所有的数组都是 Array 类的实例…

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