mysql解析json数组怎么解析(mysql json数组查询)

来源于网络,只是收集方便以后查找!从mysql5.7开始支持json字段类型,sqlserver2016版本开始支持json字段,这是一种非常好用的格式! 对记录的操作 一、创建有json字段的表 CREATETABLEt_json(idINTPRIMARYKEY,snameVARCHAR(20),infoJSON); 二、插入记录 1.插入含有json数组的记录 INSERTINTOt_json…

来源于网络,只是收集方便以后查找!从mysql 5.7开始支持json字段类型,sqlserver2016版本开始支持json字段,这是一种非常好用的格式!

对记录的操作

一、创建有json字段的表

CREATE TABLE t_json(id INT PRIMARY KEY, sname VARCHAR(20) , info JSON);

二、插入记录

1.插入含有json数组的记录

INSERT INTO t_json(id,sname,info) VALUES( 1, ‘name1’, JSON_ARRAY(1, “abc”, NULL, TRUE, CURTIME()));

2.插入含有json对象的记录

INSERT INTO t_json(id,sname,info) VALUES( 2, ‘name2’, JSON_OBJECT(“age”, 20, “time”, now()));

INSERT INTO t_json(id,sname,info) VALUES( 3, ‘name3’, ‘{“age”:20, “time”:”2018-07-14 10:52:00″}’);

三、查询记录

1.查询记录

SELECT sname,JSON_EXTRACT(info,’$.age’) FROM t_json;

SELECT sname,info->’$.age’ FROM t_json;

2.查询key

SELECT id,json_keys(info) FROM t_json;

四、修改记录

1.增加键

UPDATE t_json SET info = json_set(info,’$.ip’,’192.168.1.1′) WHERE id = 2;

2.变更值

UPDATE t_json SET info = json_set(info,’$.ip’,’192.168.1.2′) WHERE id = 2;

3.删除键

UPDATE t_json SET info = json_remove(info,’$.ip’) WHERE id = 2;

创建json值函数

一、JSON_ARRAY 生成json数组

//JSON_ARRAY(val1,val2,val3…)

//生成一个包含指定元素的json数组。

SELECT JSON_ARRAY(1, “abc”, NULL, TRUE, CURTIME()); — [1, “abc”, null, true, “10:37:08.000000”]

二、JSON_OBJECT 生成json对象

//JSON_OBJECT(key1,val1,key2,val2…)

//生成一个包含指定K-V对的json object。如果有key为NULL或参数个数为奇数,则抛错。

SELECT JSON_OBJECT(‘age’, 20, ‘time’, now()); — {“age”: 20, “time”: “2021-06-18 14:49:57.000000”}

三、JSON_QUOTE 加”号

//JSON_QUOTE(json_val)

//将json_val用”号括起来。

SELECT JSON_QUOTE(‘[1,2,3]’); — “[1,2,3]”

搜索json值函数

一、JSON_CONTAINS 指定数据是否存在

set @j = ‘{“a”: 1, “b”: 2, “c”: {“d”: 4}}’;

//JSON_CONTAINS(json_doc, val[, path])

//查询json文档是否在指定path包含指定的数据,包含则返回1,否则返回0。如果有参数为NULL或path不存在,则返回NULL。

SELECT JSON_CONTAINS(@j, ‘4’, ‘$.c.d’); — 1

二、JSON_CONTAINS_PATH 指定路径是否存在

//JSON_CONTAINS_PATH(json_doc, one_or_all, path[, path] …)

//查询是否存在指定路径,存在则返回1,否则返回0。如果有参数为NULL,则返回NULL。

//one_or_all只能取值”one”或”all”,one表示只要有一个存在即可;all表示所有的都存在才行。

SELECT JSON_CONTAINS_PATH(@j, ‘one’, ‘$.a’, ‘$.e’); — 1

SELECT JSON_CONTAINS_PATH(@j, ‘all’, ‘$.a’, ‘$.c.d’); — 1

三、JSON_EXTRACT 查找所有指定数据

//JSON_EXTRACT(json_doc, path[, path] …)

//从json文档里抽取数据。如果有参数有NULL或path不存在,则返回NULL。如果抽取出多个path,则返回的数据封闭在一个json array里。

set @j2 = ‘[10, 20, [30, 40]]’;

SELECT JSON_EXTRACT(‘[10, 20, [30, 40]]’, ‘$[1]’); — 20

SELECT JSON_EXTRACT(‘[10, 20, [30, 40]]’, ‘$[1]’, ‘$[0]’); — [20, 10]

SELECT JSON_EXTRACT(‘[10, 20, [30, 40]]’, ‘$[2][*]’); — [30, 40]

四、JSON_KEYS 查找所有指定键值

//JSON_KEYS(json_doc[, path])

//获取json文档在指定路径下的所有键值,返回一个json array。如果有参数为NULL或path不存在,则返回NULL。

SELECT JSON_KEYS(‘{“a”: 1, “b”: {“c”: 30}}’); — [“a”, “b”]

SELECT JSON_KEYS(‘{“a”: 1, “b”: {“c”: 30}}’, ‘$.b’); — [“c”]

SELECT id,json_keys(info) FROM t_json;

五、JSON_SEARCH 查找所有指定值的位置

//JSON_SEARCH(json_doc, one_or_all, search_str[, escape_char[, path] …])

//查询包含指定字符串的paths,并作为一个json array返回。如果有参数为NUL或path不存在,则返回NULL。

//one_or_all:”one”表示查询到一个即返回;”all”表示查询所有。

//search_str:要查询的字符串。 可以用LIKE里的’%’或‘_’匹配。

// path:在指定path下查。

SET @j3 = ‘[“abc”, [{“k”: “10”}, “def”], {“x”:”abc”}, {“y”:”bcd”}]’;

SELECT JSON_SEARCH(@j3, ‘one’, ‘abc’); — “$[0]”

SELECT JSON_SEARCH(@j3, ‘all’, ‘abc’); — [“$[0]”, “$[2].x”]

SELECT JSON_SEARCH(@j3, ‘all’, ‘abc’, NULL, ‘$[2]’); — “$[2].x”

SELECT JSON_SEARCH(@j3, ‘all’, ’10’); — “$[1][0].k”

SELECT JSON_SEARCH(@j3, ‘all’, ‘%b%’); — [“$[0]”, “$[2].x”, “$[3].y”]

SELECT JSON_SEARCH(@j3, ‘all’, ‘%b%’, NULL, ‘$[2]’); — “$[2].x”

修改json值函数

一、JSON_ARRAY_APPEND 指定位置追加数组元素

//JSON_ARRAY_APPEND(json_doc, path, val[, path, val] …)

//在指定path的json array尾部追加val。如果指定path是一个json object,则将其封装成一个json array再追加。如果有参数为NULL,则返回NULL。

SET @j4 = ‘[“a”, [“b”, “c”], “d”]’;

//SELECT JSON_ARRAY_APPEND(@j4, ‘$[1][0]’, 3); — [“a”, [[“b”, 3], “c”], “d”]

SET @j5 = ‘{“a”: 1, “b”: [2, 3], “c”: 4}’;

SELECT JSON_ARRAY_APPEND(@j5, ‘$.b’, ‘x’); — {“a”: 1, “b”: [2, 3, “x”], “c”: 4}

SELECT JSON_ARRAY_APPEND(@j5, ‘$.c’, ‘y’); — {“a”: 1, “b”: [2, 3], “c”: [4, “y”]}

SELECT JSON_ARRAY_APPEND(@j5, ‘$’, ‘z’); — [{“a”: 1, “b”: [2, 3], “c”: 4}, “z”]

二、JSON_ARRAY_INSERT 指定位置插入数组元素

//JSON_ARRAY_INSERT(json_doc, path, val[, path, val] …)

//在path指定的json array元素插入val,原位置及以右的元素顺次右移。如果path指定的数据非json array元素,则略过此val;如果指定的元素下标超过json array的长度,则插入尾部。

SET @j6 = ‘[“a”, {“b”: [1, 2]}, [3, 4]]’;

SELECT JSON_ARRAY_INSERT(@j6, ‘$[1]’, ‘x’); — [“a”, “x”, {“b”: [1, 2]}, [3, 4]]

SELECT JSON_ARRAY_INSERT(@j6, ‘$[100]’, ‘x’); — [“a”, {“b”: [1, 2]}, [3, 4], “x”]

SELECT JSON_ARRAY_INSERT(@j6, ‘$[1].b[0]’, ‘x’); — [“a”, {“b”: [“x”, 1, 2]}, [3, 4]]

SELECT JSON_ARRAY_INSERT(@j6, ‘$[0]’, ‘x’, ‘$[3][1]’, ‘y’); — [“x”, “a”, {“b”: [1, 2]}, [3, “y”, 4]]

三、JSON_INSERT 指定位置插入

//JSON_INSERT(json_doc, path, val[, path, val] …)

//在指定path下插入数据,如果path已存在,则忽略此val(不存在才插入)。

SET @j7 = ‘{ “a”: 1, “b”: [2, 3]}’;

SELECT JSON_INSERT(@j7, ‘$.a’, 10, ‘$.c’, ‘[true, false]’); — {“a”: 1, “b”: [2, 3], “c”: “[true, false]”}

四、JSON_REPLACE 指定位置替换

//JSON_REPLACE(json_doc, path, val[, path, val] …)

//替换指定路径的数据,如果某个路径不存在则略过(存在才替换)。如果有参数为NULL,则返回NULL。

SELECT JSON_REPLACE(@j7, ‘$.a’, 10, ‘$.c’, ‘[true, false]’); — {“a”: 10, “b”: [2, 3]}

五、JSON_SET 指定位置设置

//JSON_SET(json_doc, path, val[, path, val] …)

//设置指定路径的数据(不管是否存在)。如果有参数为NULL,则返回NULL。

SELECT JSON_SET(@j7, ‘$.a’, 10, ‘$.c’, ‘[true, false]’); — {“a”: 10, “b”: [2, 3], “c”: “[true, false]”}

六、JSON_MERGE 合并

//JSON_MERGE(json_doc, json_doc[, json_doc] …)

//merge多个json文档。规则如下:

//如果都是json array,则结果自动merge为一个json array;

//如果都是json object,则结果自动merge为一个json object;

//如果有多种类型,则将非json array的元素封装成json array再按照规则一进行mege。

SELECT JSON_MERGE(‘[1, 2]’, ‘[true, false]’); — [1, 2, true, false]

SELECT JSON_MERGE(‘{“name”: “x”}’, ‘{“id”: 47}’); — {“id”: 47, “name”: “x”}

SELECT JSON_MERGE(‘1’, ‘true’); — [1, true]

SELECT JSON_MERGE(‘[1, 2]’, ‘{“id”: 47}’); — [1, 2, {“id”: 47}]

七、JSON_REMOVE 指定位置移除

//JSON_REMOVE(json_doc, path[, path] …)

//移除指定路径的数据,如果某个路径不存在则略过此路径。如果有参数为NULL,则返回NULL。

SET @j8 = ‘[“a”, [“b”, “c”], “d”]’;

SELECT JSON_REMOVE(@j8, ‘$[1]’); — [“a”, “d”]

八、JSON_UNQUOTE 去”号

//JSON_UNQUOTE(val)

//去掉val的引号。如果val为NULL,则返回NULL。

SELECT JSON_UNQUOTE(“\\”123\\””); — 123

返回json值属性的函数

一、JSON_DEPTH 深度

//JSON_DEPTH(json_doc)

//获取json文档的深度。如果参数为NULL,则返回NULL。

//空的json array、json object或标量的深度为1。

SELECT JSON_DEPTH(‘{}’), JSON_DEPTH(‘[]’), JSON_DEPTH(‘true’); — 1 1 1

SELECT JSON_DEPTH(‘[10, 20]’), JSON_DEPTH(‘[[], {}]’); — 2 2

SELECT JSON_DEPTH(‘[10, {“a”: 20}]’); — 3

二、JSON_LENGTH 长度

//JSON_LENGTH(json_doc[, path])

//获取指定路径下的长度。如果参数为NULL,则返回NULL。 

//长度的计算规则:

//标量的长度为1;

//json array的长度为元素的个数;

//json object的长度为key的个数。

SELECT JSON_LENGTH(‘[1, 2, {“a”: 3}]’); — 3

SELECT JSON_LENGTH(‘{“a”: 1, “b”: {“c”: 30}}’); — 2

SELECT JSON_LENGTH(‘{“a”: 1, “b”: {“c”: 30}}’, ‘$.b’); — 1

三、JSON_TYPE 类型

//JSON_TYPE(json_val)

//获取json文档的具体类型。如果参数为NULL,则返回NULL。

select JSON_TYPE(‘[1,2]’); — ARRAY

四、JSON_VALID 是否有效json格式

//JSON_VALID(val)

//判断val是否为有效的json格式,是为1,不是为0。如果参数为NUL,则返回NULL。

SELECT JSON_VALID(‘{“a”: 1}’); — 1

SELECT JSON_VALID(‘hello’), JSON_VALID(‘”hello”‘); — 1

附录:

函数名 描述
JSON_APPEND()(废弃的5.7.9) JSON文件追加数据
JSON_ARRAY() 创建JSON数组
JSON_ARRAY_APPEND() JSON文件追加数据
JSON_ARRAY_INSERT() 插入JSON数组
-> 在评估路径返回JSON列值;相当于json_extract()。
JSON_CONTAINS() 是否包含特定对象的JSON文档路径
JSON_CONTAINS_PATH() 无论是JSON文件包含任何数据路径
JSON_DEPTH() JSON文档的最大深度
JSON_EXTRACT() 从JSON文档返回数据
->> 在评估路径和结束引语结果返回JSON列值;相当于json_unquote(json_extract())。
JSON_INSERT() 将数据插入到JSON文档
JSON_KEYS() 从JSON文件密钥数组
JSON_LENGTH() 在JSON文档中的元素数
JSON_MERGE()(废弃的5.7.22) 合并的JSON文件,保存重复键。不json_merge_preserve()的同义词
JSON_MERGE_PATCH() 合并的JSON文件,免去重复键的值
JSON_MERGE_PRESERVE() 合并的JSON文件,保存重复键
JSON_OBJECT() 创建JSON对象
JSON_PRETTY() 版画在人类可读的格式JSON文档,每个数组元素或对象成员打印在新的行中,缩进两个空格就其母。
JSON_QUOTE() 引用JSON文档
JSON_REMOVE() 从JSON文件中删除数据
JSON_REPLACE() 在JSON文件的值替换
JSON_SEARCH() 在JSON文件价值路径
JSON_SET() 将数据插入到JSON文档
JSON_STORAGE_SIZE() 用于一个JSON文件的二进制表示形式存储空间;一个JSON柱,空间时使用的文档插入到任何部分更新之前,
JSON_TYPE() JSON值类型
JSON_UNQUOTE() JSON值而言
JSON_VALID() JSON值是否是有效的

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

(0)
上一篇 2022年5月11日 下午4:34
下一篇 2022年5月11日 下午4:35

相关推荐

  • 微信备份聊天记录在哪,微信聊天记录的3种备份方法

    微信聊天记录怎么备份?随着科技的不断发展,我们更新换代电子产品的脚步也加快了起来,但不论是更换新手机,还是为了释放手机存储空间而去清理缓存数据,都很容易造成手机中的微信聊天记录丢失,如何备份微信聊天记录呢?很简单,学会下面的两招,备份与恢复都不用愁! 微信聊天记录备份 其实备份微信聊天记录的方法还是有很多的,比如借助电脑端微信,登录后点击左下角的“备份与恢复”,选择“备份聊天记录至电脑”,再选择备…

    2022年6月8日
    840
  • 如何发现商机,最简单的商机发现办法

    发现创业良机,很多创业者都会问这个问题。其实商机就在身边,只要我们有善于发现商机的眼睛。 1.变化就是机会 人们透过这些变化,就会发现新的前景。变化可以包括:①产业结构的变化;②科技进步;③通信革新;④政府放松管制;⑤经济信息化、服务化;⑥价值观与生活形态变化;⑦人口结构变化。以人口因素变化为例,可以举出以下一些机会:为老年人提供的健康保障用品、为独生子女服务的业务项目、为年轻女性和上班女性提供的…

    2022年6月14日
    730
  • 什么品牌自行车质量好(2020年自行车十大品牌排行榜)

    自行车,又称脚踏车或单车,通常是二轮的小型陆上车辆。骑自行车的好处?自行车运动是一种最能改善人们心肺功能的耐力性有氧运动。骑自行车能减肥养生、改善体质、提高免疫、益寿延年已经得到全世界广泛公认。下面跟小编一起来看看全球十大顶级自行车品牌。 全球十大顶级自行车品牌排行榜 1、MARMOT土拨鼠 MARMOT中文名土拨鼠,俗称旱獭。MARMOT土拨鼠由美国高端自行车品牌CANNONDALE前任总裁等人…

    2022年10月27日
    450
  • 康宝油烟机怎么样( 油烟机吸力的判断方法)

    随着科技的发达,厨房中有了像吸油烟机这样的产品后,给人们的生活带来了很多便利,既省去炒菜时因油烟过重导致的一些身体健康问题,也减少了生活中的一些不必要的麻烦。 而有着恒久大吸力的吸油烟机更是能提高整个厨房环境的质量,确保里面的环境得到改善,因此超大吸力的油烟机是家庭主妇们的首选。 作为中国知名的厨卫家电品牌,康宝先后获得了“部优产品”、“全国用户满意产品”、“广东省名牌产品”、“广东著名商标”、“…

    2022年9月8日
    590
  • 爱淘宝是什么网站,爱淘宝网站功能详细介绍

    说起淘宝购物,可能很多人都是轻车熟路了,但是说到爱淘宝,很多人就不清楚爱淘宝和淘宝的区别了,有些人还以为爱淘宝跟淘宝就是一样的,没有什么区别,但是如果没区别的话,又怎么会同时存在,而且名字还不同,所以说两者还是有区别的,只不过大家不知道爱淘宝和淘宝的区别罢了。 可能有些人不仅在淘宝上买过东西,可能也在爱淘宝上购物过,但可能以为两者是差不多,所以就没多大留意吧,其实爱淘宝和淘宝的区别也不是很明显,尤…

    2022年8月18日
    760
  • 海东青是什么,世界上飞得最高和最快的鸟

    《本草纲目》中记载: “雕出辽东,最俊者谓之“海东青”。” 据传 海东青是世界上飞得最高和最快的鸟 是满族的最高图腾! 代表: 勇敢、智慧、坚忍、正直、强大、 开拓、进取、永远向上、永不放弃的精神!!! 海东青不单纯是一种真正存在的物种 类似于汉族的龙图腾崇拜 据现代动物学家考证: 海东青属鹰科 学名矛隼 是一种美丽的中型猛禽 也是体形较大的隼类 所以又有巨隼之称 其体长56~61厘米 体重131…

    2022年10月3日
    680
  • 微信公众号有什么用,微信公众号作用与意义

    创业指数更新到现在已经更新了很多文章了,虽然中断了一段时间的更新,但现在每天更新原创,更新干货,我想每天的推送内容的可看性、可借鉴性、实用性还是很高的,一直以来我总围绕着微信这个话题作为创业指数的主要推送内容,可是微信到底有什么用,你们真的了解吗? 不瞒你们说,我一直以来都靠着微信公众号赚钱,而且这部分收入不可小觑,而随着微信的不断更新升级,套路是越来越多,总有人说微信的红利期过了,没意思了,我想…

    2022年7月4日
    610
  • wordpress制作网站流程,手把手教你如何用wordpress搭建网站

    现在开源的博客很多,但是考虑到wordpress对网站的seo做的很好,插件也多。并且全世界流量排名前1000万的网站有33.4%是用Wordpress搭建的!所以尝试用Wordpress搭建一个网站,还挺方便的。 基于CentOS7搭建 yum的一些命令 先把php版本升级为7 https://blog.csdn.net/weixin_42890981/article/details/83685…

    2022年7月16日
    1270
  • 破解wifi密码的神器是什么,这七款神器都能一步搞定

    1、RainbowCrack RainbowCrack是一个哈希破解工具,使用大规模时空折中(Time-memory trade off)处理技术加快密码破解,因此比传统暴力破解工具要快。用户无需自己生成彩虹表,RainbowCrack的开发者已经准备好了LM彩虹表、NTLM彩虹表和MD5彩虹表,而且都是免费的。 2、Wfuzz Wfuzz是一个web应用密码暴力破解工具,还可以用来查找隐藏资源如…

    2022年9月11日
    2720
  • 增值税票是什么,一分钟让你了解增值税票

    解决发票实务中的许多问题,都需要对发票的基础知识有所了解。《国家税务总局货物和劳务税司关于做好增值税发票使用宣传辅导有关工作的通知》(税总货便函〔2017〕127)的附件《增值税发票开具指南》基于当时的政策,对通过增值税发票管理新系统开具的发票的相关政策进行了梳理。当时通过增值税发票管理新系统开具的发票种类包括增值税专用发票、增值税普通发票、增值税电子普通发票和机动车销售统一发票。本文在此基础上,…

    2022年9月18日
    350

发表回复

登录后才能评论

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信