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
您可能感兴趣
- mysql优化使用方法(详解Mysql函数调用优化)
- mysql的常见优化(详解GaussDB for MySQL性能优化)
- mysqlnull所占空间(详解mysql三值逻辑与NULL)
- mysql中如何设置多个主键(Mysql 增加主键或者修改主键的sql语句操作)
- 数据库mysql基本知识(深入理解r2dbc在mysql中的使用)
- mysql数据库触发器(MySQL中使用游标触发器的方法)
- mysql服务器端安装步骤(windows下jsp+mysql网站环境配置方法)
- 怎么把csv文件导入mysql(mysql导入csv的4种报错的解决方法)
- 软件测试常用mysql语句(MySQL压力测试工具Mysqlslap的使用)
- 2021-10-04 01:06:07
- mysql8.0.20安装教程图解(mysql 8.0.24 安装配置方法图文教程)
- centos7可以装mysql吗(详解腾讯云CentOS7.0使用yum安装mysql及使用遇到的问题)
- mysql密码过期怎么改(年底了,你的mysql密码安全吗)
- mysqltruncate(MYSQL中Truncate的用法详解)
- mysqlinnodb数据存储格式(MySQL InnoDB ReplicaSet副本集简单介绍)
- mysql 查询json(MySQL处理JSON常见函数的使用)
- 今天要穿什么颜色(今天要穿什么颜色的衣服最吉利)
- 一道高中题-求杯子的高度(一道高中题-求杯子的高度)
- 网坛停摆三巨头亏损惨重,费德勒跌幅88 纳达少赚2400万(网坛停摆三巨头亏损惨重)
- Beyond 版本《无人深空》主线任务攻略 阿特拉斯之道(版本无人深空主线任务攻略)
- 全球科技界最有钱大佬TOP 15 你知道几位(全球科技界最有钱大佬TOP)
- 2主力后腰缺阵 泰山队奇兵有望获重用,赛季0出场,迎来中超首秀(泰山队奇兵有望获重用)
热门推荐
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9