mysql json

官方文档
json 适用于text json等格式

  • 判断是否json格式 json_valid(col)
  • 转化为json格式 json_quote(col)
  • 从json取值 json_extract(col,’ . k e y ′ ) 或 者 c o l − > ′ .key') 或者 col->' .key)col>.key’

例子

一张需要审核的表

CREATE TABLE `json_test` (
 `id` int NOT NULL AUTO_INCREMENT,
 `sort` int NOT NULL DEFAULT '0',
 `content` text,
  `review` tinyint(1) DEFAULT '0',
 PRIMARY KEY (`id`)
) ENGINE=InnoDB  CHARSET=utf8;

插入数据
在这里插入图片描述
其中sort代表排序,content里面代表要更细的排序,review 1代表审核通过
要求如下:

1.如果审核通过,查询sort值
2.如果审核未通过,查询content里面sort的值
3.最终展示列表都是最新的。
4.部分content里面的格式有问题
处理思路:
* 使用json_valid判断,如果content符合json格式的话直接用,否则使用json_quote转化一下,确保都能使用正常json格式
* where 条件里面使用判断语句
* 查询sort或者content.sort为5的数据
select j.*,jt.content_json from json_test j
inner join 
(select id, case when json_valid(content) then content else json_quote(content) end as content_json from json_test)jt 
on j.id=jt.id
where 
case when review=1 then sort=5 
else content_json->'$.sort'=5 end

结果:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值