技术饭

mysql中json_contains、json_extract等json查询方法的使用

copylian    0 评论    29629 浏览    2020.12.17

新版 Mysql 中加入了对 JSON Document 的支持,可以创建 JSON 类型的字段,并有一套函数支持对JSON的查询、修改等操作。

JSON是一种轻量级的数据交换格式,采用了独立于语言的文本格式,类似XML,但是比XML简单,易读并且易编写。对机器来说易于解析和生成,并且会减少网络带宽的传输。

JSON的格式非常简单:名称/键值。之前MySQL版本里面要实现这样的存储,要么用VARCHAR要么用TEXT大文本。 MySQL5.7发布后,专门设计了JSON数据类型以及关于这种类型的检索以及其他函数解析。

其中json_containsjson_extract是很常用的查询数据方法。

1、json_extract使用,其中ThinkPHP5.1使用的json方法就是这个方法

根据表字段的json内容进行查询,需使用json_extract函数;表字段为content,json内容包含关键字method

查询语句:SELECT * FROM user WHERE   json_extract(content,"$.method") = "POST";

//TP5.1查询     

$data = \Db::name('user')->field('id,recommend,name,thumb,customer_id,cate_ids')->where($where)->where(function ($query) use ($cate_ids) {

      //闭包查询

      foreach ($cate_ids as $key => $value) {

                  $whereOr = [];

                  $whereOr[] = ['cate_ids->cate_id_' . $value, '=', $value];

                  $query->whereOr($whereOr);

      }

})->order($order)->page($page, $limit)->select();


2、json_contains、json_array的使用

1608221190(1).png

要从此表中匹配到包含上述四个关键字中的任意若干个,可这样:

SELECT * FROM user WHERE JSON_CONTAINS(JSON_ARRAY("我","想","销","存单"),keywords->'$.keywords') ORDER BY weights DESC;

执行结果:

1608221203(1).png

另附上部分sql,以防之后忘记

SELECT * FROM user;

SELECT * FROM user WHERE keywords LIKE "%销%";

SELECT * FROM user WHERE JSON_EXTRACT(keywords,'$.keywords') LIKE "%销%";

SELECT * FROM user WHERE keywords -> '$.keywords' LIKE "%销%";

其中第三条sql和第四条sql是等效的。


//Tp5.1查询

$momo = \Db::query("select switchs->'$[*]' from timer where  JSON_CONTAINS(switchs->'$[*].id', '\"$id\"', '$') and JSON_CONTAINS(switchs->'$[*].fid', '\"$fid\"', '$') and JSON_CONTAINS(switchs->'$[*].pid', '\"$pid\"', '$')");

参考:https://www.cnblogs.com/xyj179/p/11451593.html

飓风呀
感谢你的支持,我会继续努力!
扫码打赏,感谢您的支持!

文明上网理性发言!

  • 还没有评论,沙发等你来抢