mysql根据json字段内容作为查询条件(包括json数组)检索数据
作者:新林。 发布时间:2024-01-13 00:50:50
标签:mysql,json,查询
最近用到了mysql5.7的json字段的检索查询,发现挺好用的,记录一下笔记
我们有一个日志表,里面的data字段是保存不同对象的json数据,遇到想根据里面的json的字段内容作为条件查询的情况
mysql根据json字段的内容检索查询数据
使用 字段->'$.json属性'进行查询条件
使用json_extract函数查询,json_extract(字段,"$.json属性")
根据json数组查询,用JSON_CONTAINS(字段,JSON_OBJECT('json属性', "内容"))
mysql5.7以上支持json的操作,以及增加了json存储类型
一般数据库存储json类型的数据会用json类型或者text类型
注意:用json类型的话
1)JSON列存储的必须是JSON格式数据,否则会报错。
2)JSON数据类型是没有默认值的。
查询根据表字段的json内容进行查询
首先创建表
create table log(
id int not null,
content varchar(255),
createTime TIMESTAMP,
data text
)
插入几个测试数据
执行查询sql
使用 字段->’$.json属性’进行查询条件
select * from log where data->'$.id' = 142;
或
select data->'$.id' id,data->'$.name' name from log where data->'$.id' = 142;
测试根据json数组的字段查询
1.再建一个表log2,插入几条json数组数据
[{
"id": "141",
"name": "xxx",
"type": "input"
},
{
"id": "142",
"name": "xin",
"type": "textarea"
}
]
查询json数组里面对象的id等于142的记录
用JSON_CONTAINS(字段,JSON_OBJECT(‘json属性’, “内容”))
select * from log2 where JSON_CONTAINS(data,JSON_OBJECT('id', "142"))
参考:
Simon格子的MySQL 5.7新增对JSON支持
来源:https://blog.csdn.net/qq_21187515/article/details/90760337
0
投稿
猜你喜欢
- OK,首先写一个python socket的server段,对开放三个端口:10000,10001,10002.krondo的例子中是每个s
- 自从认识了 CircleCI 之后,基本上都在用这个了。相比于之前用的travis-ci ,CircleCI 丑是丑了点,但是相比与 tra
- 本文介绍了Python小波分析库Pywavelets,分享给大家,具体如下:# -*- coding: utf-8 -*- import n
- 1.重命名表方法使用 RENAME TABLE 语句或 ALTER TABLE 语句都可以对表进行重命名,基本语法如下:# RE
- golang sort package: https://studygolang.com/articles/3360sort 操作的对象通常
- 1. 通过windows attrib 命令获取文件隐藏属性Syntax ATT
- 前两天特意装了一下IETester,用以方便测试,装好后使用发现IE8有两个地方需要大家注意。IE5MAC的过滤器对IE8 Beta 1版同
- list.asp<%@LANGUAGE="VBSCRIPT" CODEPAGE="936&qu
- 1 前言在 Java 和 js 中,lambda箭头函数是十分常见的操作,这种表达方式在使用时非常的简便。在python的语法中也有应用场景
- 前言既然在Pathlib库中提到了glob()函数,那么我们就专门用一篇内容讲解文件名的匹配。其实我们有专门的一个文件名匹配库就叫:glob
- 这篇文章主要介绍了python sorted方法和列表使用解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,
- 在应用SA-FileUp时,必须确认用户已对目的路径有读、写、删除的权力。在多文件上传中,由于浏览器不支持SIZE= 属性,所以对多文件的情
- 其实 selenium启动窗口的时候就是 使用了subprocess.Popen 启动的驱动程序的,只要在启动的时候加上启动不显示窗口的参数
- “ 使用python实现协议中常见的TCP长连接框架。”分析多了协议就会发现,很多的应用,
- 目录典型的函数装饰器叠放装饰器参数化装饰器标准库中的装饰器functools.wrapsfunctools.lru_cachefunctoo
- 最近开始在项目中使用Quickwork For Asp,虽然该框架是自己独立完成的,不过功能没做过详细的总结,所以很多参数总是会弄错,毕竟鱼
- 使用HTMLTestRunner输出的测试报告中,标题和错误说明的中文乱码。环境:python v3.6HTMLTestRunner v0.
- 前言大家都知道Python的优点是开发效率高,使用方便,C++则是运行效率高,这两者可以相辅相成,不管是在Python项目中嵌入C++代码,
- //获得视频文件的缩略图function getVideoCover($file,$time,$name) { &nb
- 最近在学习Python3网络爬虫开发实践(崔庆才 著)刚好也学习到他使用代理爬取公众号文章这里,但是照着他的代码写,出现了一些问题。在这里我