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

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

Mysql小技巧

个人博客站点:
简书: 😽 猫轻王 https://www.jianshu.com/u/6cce817646be
掘金: 😽 猫轻王 https://juejin.cn/user/1640918680347453
CSDN: 😽 猫轻王 https://blog.csdn.net/moer0
个人项目主页:
https://github.com/moercat


前言

JSON 可以将 JavaScript 对象中表示的一组数据转换为字符串,然后就可以在函数之间轻松地传递这个字符串,或者在异步应用程序中将字符串从 Web 客户机传递给服务器端程序。这个字符串可以表示数组和复杂的对象,而不仅仅是键和值的简单列表,在Mysql中存储Json字符串可以极大的简便存储的复杂度,而与此同时,读取数据库也就成了很多人首先遇到的问题。


示例:{ “key”: “value” }

一、Json是什么?

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。JSON采用完全独立于语言的文本格式,这些特性使JSON成为理想的数据交换语言。易于人阅读和编写,同时也易于机器解析和生成。

二、不同情况

1.模糊查询json类型字段

存储的数据格式(字段名 people_json):

{“name”: “zhangsan”, “age”: “13”, “gender”: “男”}

代码如下(示例):

select * from table_name  where people_json->'$.name' like '%zhang%'

2.精确查询json类型字段

存储的数据格式(字段名 people_json):

{“name”: “zhangsan”, “age”: “13”, “gender”: “男”}

代码如下(示例):

select * from table_name  where people_json-> '$.age' = 13

3.模糊查询JsonArray类型字段

存储的数据格式(字段名 people_json):

[{“name”: “zhangsan”, “age”: “13”, “gender”: “男”}]

代码如下(示例):

select * from table_name  where people_json->'$[*].name' like '%zhang%'

4.精确查询JsonArray类型字段

存储的数据格式(字段名 people_json):

[{“name”: “zhangsan”, “age”: “13”, “gender”: “男”}]

代码如下(示例):

select * from table_name  where JSON_CONTAINS(people_json,JSON_OBJECT('age', "13"))

总结

针对数据库中存储的不同Json类型,sql语句已经拥有着简便的方法,只需要了解便可以轻松使用。

希望这个博客能对你有所益处。我是轻王,我为自己代言。
要去除JSON字符串中的转义符号,可以使用Java中的字符串处理方法来实现。首先,我们可以使用Java自带的String类提供的replaceAll()方法来替换掉所有的转义符号。此方法接收两个参数,第一个参数是要替换的字符串的正则表达式,第二个参数是替换后的字符串。 在JSON字符串中,转义符号一般以反斜杠(\)开头,例如\,\\,\"等。所以,我们可以使用正则表达式"\\\\"来匹配反斜杠。因为Java中\也是一个特殊的转义字符,所以在正则表达式中,需要使用"\\\\"来表示一个反斜杠。 下面是一个示例代码,演示如何去除JSON字符串中的转义符号: ``` public class Main { public static void main(String[] args) { String jsonString = "{\"name\":\"John\",\"age\":30,\"city\":\"New York\"}"; String replacedString = jsonString.replaceAll("\\\\", ""); System.out.println(replacedString); } } ``` 运行上述代码,输出结果为: ``` {"name":"John","age":30,"city":"New York"} ``` 可以看到,原始的JSON字符串中的转义符号已经被替换为空字符串,成功去除了转义符号。 需要注意的是,在替换转义符号之后,得到的字符串可能存在其他特殊字符,比如Unicode编码字符等。如果需要进一步处理这些特殊字符,可以使用第三方的JSON库,比如Gson或Jackson来解析JSON字符串。这些库提供了更高级的JSON处理功能,可以更方便地解析和处理JSON数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

猫轻王

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值