我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL中查询json格式的字段实例详解

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL中查询json格式的字段实例详解

工作开发过程遇到一个需求:需要动态存储客户的姓名、手机号码、身份证、证件类型,意思是可能前端会传一个人或二个人或者三个人的信息是动态的不固定人数的四个字段(姓名、手机号码、身份证、证件类型)。

前端页面如下:

这是前端图片

我是使用List来接收前端传过来 json,mysql 用 varchar 来保存这个 json 数组


[{
	"cardId": "110101199003072316",
	"cstName": "张双儿1",
	"cstMobile": "13263654144",
	"idCardType": "1"
}, {
	"cardId": "11010119900307571X",
	"cstName": "张双儿2",
	"cstMobile": "13263654144",
	"idCardType": "1"
}]

产品提出来的需求是要模糊查询这些联名客户信息,一开始我错误的写法:

select * from signCustomerGroup like ‘%儿%'

但是后来发现有问题,比如 模糊输入一个字母 c ,就会把左边‘cardId' 的英文字段名称匹配上。
后来我了解到 MySQL 5.7 以后版本加入了 json 类型,可以使用json类型的一些函数直接查询json格式的某个字段。

正确语法如下:

表字段:

id sign_customer_info_ext
1 [{“cstName”:“hhjk”,“cstMobile”:“14258669888”,“idCardType”:“1”,“cardId”:“460101199601012516”}]
2 [{“cstName”:“ghhj中文1355”,“cstMobile”:“18253558608”,“idCardType”:“1”,“cardId”:“460101199601012815”},{“cstName”:“fhjj重要133366”,“cstMobile”:“15555555555”,“idCardType”:“1”,“cardId”:“460101199601012313”}]

主要使用的 SQL 函数是 json_extract() ,它的作用是:从JSON格式查找所有指定数据

1. json 数组查询


模糊查询 json 数组格式的字段中某个字段:
使用方式:
SELECT * FROM 表名 WHERE json_extract(字段名,"$[*].json中key") like '%需要搜索的值%';
实例:
SELECT * FROM table WHERE json_extract(sign_customer_info_ext,"$[*].cstName") like '%h%';

精准查询(注意:精准查询必须写明所查询字段所属数组那个下标,比如查排在一个就是 [0],第二个就是 [1])
SELECT id,sign_customer_info_ext FROM table WHERE json_extract(sign_customer_info_ext,"$[0].cstName") = 'ghhj中文1355';

2.单个 json 查询

前端和mysql数据库中 单个 json 参数:


{
	"cstName": "马云",
	"cstMobile": "17879767646",
	"idCardType": "1",
	"cardId": "E4813980"
}

模糊查询单个 json 查询:
使用方式:
SELECT id,sign_customer_info_ext FROM 表名 WHERE json_extract(字段名,"$.json中key") like '%马云%';
实例:
SELECT id,sign_customer_info_ext FROM table WHERE json_extract(sign_customer_info_ext,"$.cstName") like '%马云%';

总结

到此这篇关于MySQL中查询json格式的文章就介绍到这了,更多相关MySQL查询json格式字段内容请搜索自学编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持自学编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL中查询json格式的字段实例详解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL中查询json格式的字段实例详解

工作开发过程遇到一个需求:需要动态存储客户的姓名、手机号码、身份证、证件类型,意思是可能前端会传一个人或二个人或者三个人的信息是动态的不固定人数的四个字段(姓名、手机号码、身份证、证件类型)。 前端页面如下:我是使用List来接收前端传过来
2022-05-14

Mysql中JSON字段的值的实现示例

我们在查询mysql数据时,查询某个字段的数剧是我们经常接触的,直接使用sql语句或者更方便的直接使用数据库的orm语句查询。但是如果需要查询某个json字段里面的某些数据,orm模型可能都无法达到效果,还不如直接使用sql语句进行查询来的
Mysql中JSON字段的值的实现示例
2024-09-11

Spring中字段格式化的使用详解

Spring提供的一个core.convert包是一个通用类型转换系统。它提供了统一的ConversionService API和强类型的Converter SPI,用于实现从一种类型到另一种类型的转换逻辑。

mysql中json类型字段的基本用法实例

目录前言基本环境jsON类型字段常用操作插入JSON类型数据查询JSON类型数据更新JSON类型数据中的特定字段匹配JSON类型数据中的特定字段结语前言mysql从5.7.8版本开始原生支持了JSON类型数据,同时可以对JSON类型字段中
2022-08-12

Mongoose实现虚拟字段查询的方法详解

前言 不知道大家知不知道,mongoose为数据模型提供了虚拟属性, 借此可以更加一致地、方便地读写模型属性,类似于C#或Java中的访问器。 我们知道虚拟属性在Query阶段一定是查不到的,因为事实上MongoDB并没有存储这些属性。 但
2022-06-04

mysql 多个字段拼接的实例详解

Mysql的查询结果行字段拼接,可以用下面两个函数实现: 1. concat函数mysql> select concat('1','2','3') from test ; +---------------------+ | concat('
2022-05-27

mysql查询字符串中某个字符串出现的次数(实例详解)

目录mysql查询字符串中某个字符串出现的次数1.首先查js询"ss"的长度2.查询"http://www.cppcns.comjhttp://www.cppcns.comjhshdglddiiiisssddddjjsssjjssjj"的长
2023-04-07

Postgresql数据库中的json类型字段使用示例详解

目录1. json概述2. PostgreSQL数据库中使用Json类型字段2.1. 创建表定义字段信息2.2. 增加2.3. 查询键值2.3.1. 查询键2.3.2. 查询值2.3.3. where查询条件使android用json键值作
2023-02-09

详解MySQL like如何查询包含'%'的字段(ESCAPE用法)

在SQl like语句中,比如SELECT * FROM user WHERE username LIKE '%luchi%' SELECT * FROM user WHERE username LIKE '_luchi_',% 作为通配符
2022-05-11

MySQL范围查询优化的场景实例详解

目录思考题范围查询-基础场景一: a = 1 and b = 2 and c = 3场景二: a > 1 and b = 2场景三:a > 1 and b = 2 and c > 3编程客栈场景四: a > 1 ORDER BY b场景五:
2022-06-13

编程热搜

目录