mysql存储json的方式(MySQL中查询json格式的字段实例详解)
类别:数据库 浏览量:2432
时间:2021-10-22 07:38:19 mysql存储json的方式
MySQL中查询json格式的字段实例详解工作开发过程遇到一个需求:需要动态存储客户的姓名、手机号码、身份证、证件类型,意思是可能前端会传一个人或二个人或者三个人的信息是动态的不固定人数的四个字段(姓名、手机号码、身份证、证件类型)。
前端页面如下:
我是使用List
|
[{ "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格式字段内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
原文链接:https://blog.csdn.net/weixin_46756314/article/details/112286652
您可能感兴趣
- thinkphp5.1手动连接mysql数据库(thinkphp5框架结合mysql实现微信登录和自定义分享链接与图文功能示例)
- oraclemysql知识点(详解Mysql和Oracle之间的误区)
- mysql怎么给查询权限(MySql设置指定用户数据库查看查询权限)
- mysql权限设置
- dockermysql配置详解(Docker 部署Mysql 服务和Redis 服务的方法)
- mysqlset用法(mysql descDESCRIBE命令实例讲解)
- mysql中timestamp类型的CURRENT_TIMESTAMP 和ON UPDATE CURRENT_TIMESTAMP属性
- mysql用户删除了如何设置(MySQL两种删除用户语句的区别delete user和drop user)
- python在mysql创建数据库(python3对接mysql数据库实例详解)
- mysql数据库使用规则(mysql数据库基本语法及操作大全)
- mysql怎么看脱机数据(MYSQL电话号码,身份证数据脱敏的实现)
- mysql主从模式与读写分离(磁盘写满导致MySQL复制失败的解决方案)
- mysql清空数据库所有表格(MySQL用truncate命令快速清空一个数据库中的所有表)
- MySQL中NULL和空值的区别
- mysql有哪些索引和聚簇索引(MySQL 独立索引和联合索引的选择)
- mysql查看数据库cpu使用率(CPU 以及内存从哪些方面影响 MySQL 性能?)
- 人从众 火炎焱 全椒再现 正月十六走太平 的魅力(人从众火炎焱全椒再现)
- 官宣 全椒籍明星许海峰 奚秀兰 方芳 王璐瑶携手回家 走太平(全椒籍明星许海峰)
- 以前全椒人是怎么过冬的 满满都是回忆(以前全椒人是怎么过冬的)
- NVIDIA显卡份额冲上88 A饭发愁 游戏优化恐没A卡份了(NVIDIA显卡份额冲上88A饭发愁)
- AMD YES A卡还是N卡 A卡和N卡的区别(AMDYESA卡还是N卡)
- 以后显卡多了一个新选择,N卡和A卡外又多了个I卡(以后显卡多了一个新选择)
热门推荐
- mvc renderpartial
- dede数据统计(DEDE [field:global name=autoindex/] 按序号排列从0从1开始)
- tortoisesvn解析失败(TortoiseSvn小乌龟安装最新图文详细教程)
- mysql中查询数据合并(Mysql合并结果接横向拼接字段的实现步骤)
- mysql mvcc 流程(Mysql MVCC机制原理详解)
- 面试二叉树问的多吗(面试官:谈谈你对索引的认知系列之B-树)
- mysql中基本语句(MySQL中explain语句的基本使用教程)
- javascript怎么生成html控件(JavaScript+html实现前端页面滑动验证2)
- CSS伪元素:before, :after
- docker怎么增加端口(docker 添加端口及获取dockerfile的方法)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9