mysql 查询json相关

mysql数据库数据如图,存放的是json字符串

现在需要进行模糊查询,查询productId中有76的

select bace.name,bace.target->'$.productId'
from bill_coupon as bace
where FIND_IN_SET('76', json_unquote(json_extract(bace.target,'$.productId'))); 

1、json_extract 获取json中指定的值

获取指定json字符串中指定的属性值,以下三种等同:

json_extract(target,'$.productId')

target->'$.productId'

target->>'$.productId' //可以有两个尖括号

2、json_unquote 去掉查询结果中首尾的双引号

去除双引号后,才会是 find_in_set('76',"76,77,79")
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值