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

来自网络,只是方便以后收藏和查找!从mysql 5.7开始支持Json字段类型,从sqlserver2016开始支持json字段,非常好用的格式!对记录的操作I .用json字段创建一个表创建表t_json(id INT

本文最后更新时间:  2023-04-11 06:26:41

来自网络,只是方便以后收藏和查找!从mysql 5.7开始支持Json字段类型,从sqlserver2016开始支持json字段,非常好用的格式!

对记录的操作

I .用json字段创建一个表

创建表t_json(id INT主键,sname VARCHAR(20),info JSON);

二。插入记录

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

插入到t_json(id,sname,info)值(1,‘name1 & # 8217,JSON_ARRAY(1,“abc & # 8221,NULL,TRUE,curti me()));

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

插入到t_json(id,sname,info)值(2,‘name2 & # 8217,JSON _ OBJECT(“年龄”, 20, “时间”,现在()));

插入到t_json(id,sname,info)值(3,‘name3 & # 8217, ‘{“年龄”:20, “时间”:”2018-07-14 10:52:00″}’);

三。查询记录

1.查询记录

SELECT sname,JSON_EXTRACT(info,’$.年龄’)来自t _ json

选择名称,信息->’$.年龄’FROM t _ json

2.查询关键字

SELECT id,JSON _ keys(info)FROM t _ JSON;

四。记录的修改

1.添加密钥

UPDATE t _ JSON SET info = JSON _ SET(info,’$.ip & # 8217,’192.168.1.1′)其中id = 2;

2.更改值

UPDATE t _ JSON SET info = JSON _ SET(info,’$.ip & # 8217,’192.168.1.2′)其中id = 2;

3.删除键

UPDATE t _ JSON SET info = JSON _ remove(info,’$.ip & # 8217)其中id = 2;

创建json值函数

I. json_ARRAY生成json数组

//JSON_ARRAY(val1,val2,val3 & # 8230)

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

SELECT JSON_ARRAY(1,“abc & # 8221,NULL,TRUE,curti me());—[1, “abc & # 8221,null,true,“10:37:08.000000”]

其次,json_OBJECT生成json对象

//JSON_OBJECT(key1,val1,key2,val2 & # 8230)

//生成包含指定K-V对的json对象。如果一个键为空或者参数的数量为奇数,就会抛出一个错误。

SELECT JSON _ OBJECT(‘年龄’, 20, ‘时间’,现在());—{“年龄”: 20, “时间”: “2021-06-18 14:49:57.000000”}

三。JSON _ QUOTE plus & # 8221编号

//JSON_QUOTE(json_val)

//使用json_val与”将数字括起来。

SELECT JSON _ QUOTE(‘[1,2,3]’);—“[1,2,3]”

搜索json值函数

I. JSON_CONTAINS指定数据是否存在

set @ j = & # 8216{“一”: 1, “b & # 8221: 2, “c & # 8221: {“d & # 8221: 4}}’;

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

//查询json文档是否包含指定路径中的指定数据。如果是,它将返回1;否则,它将返回0。如果参数为NULL或路径不存在,则返回NULL。

SELECT JSON_CONTAINS(@j,‘4’, ‘$ .c.d & # 8217);—一个

二。JSON_CONTAINS_PATH指定路径是否存在

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

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

//one_or_all只能取值”一”或者”所有”,一是指只要有一个;所有意味着一切都存在。

SELECT JSON_CONTAINS_PATH(@j,‘一’, ‘$.一’, ‘$.e & # 8217);—一个

SELECT JSON_CONTAINS_PATH(@j,‘所有’, ‘$.一’, ‘$ .c.d & # 8217);—一个

三。JSON_EXTRACT查找所有指定的数据

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

//从json文档中提取数据。如果参数为NULL或路径不存在,则返回NULL。如果提取了多个路径,那么返回的数据将包含在一个json数组中。

set @ j2 = & # 8216[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数组。如果参数为NULL或路径不存在,则返回NULL。

SELECT JSON _ KEYS(‘{“一”: 1, “b & # 8221: {“c & # 8221: 30}}’);—[“一”, “b & # 8221]

SELECT JSON _ KEYS(‘{“一”: 1, “b & # 8221: {“c & # 8221: 30}}’, ‘$.b & # 8217);—[“c & # 8221]

SELECT id,JSON _ keys(info)FROM t _ JSON;

V. JSON_SEARCH查找所有指定值的位置

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

//查询包含指定字符串的路径,并将其作为json数组返回。如果有参数NUL或路径不存在,则返回NULL。

//one _ or _ all:”一”指示将返回一个查询;”所有”表示查询全部。

//search_str:要查询的字符串。你可以在LIKE中使用’%’或' _ '匹配。

// path:在指定路径下检查。

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

SELECT JSON_SEARCH(@j3,‘一’, ‘abc & # 8217);—“$[0]”

SELECT JSON_SEARCH(@j3,‘所有’, ‘abc & # 8217);—[“$[0]”, “$[2].x & # 8221]

SELECT JSON_SEARCH(@j3,‘所有’, ‘abc & # 8217,NULL,‘$[2]’);—“$[2].x & # 8221

SELECT JSON_SEARCH(@j3,‘所有’, ’10’);—“$[1][0].k & # 8221

SELECT JSON_SEARCH(@j3,‘所有’, ‘% b % & # 8217);—[“$[0]”, “$[2].x & # 8221, “$[3].y & # 8221]

SELECT JSON_SEARCH(@j3,‘所有’, ‘% b % & # 8217,NULL,‘$[2]’);—“$[2].x & # 8221

修改json值函数

I. JSON_ARRAY_APPEND在指定位置追加数组元素

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

//在指定路径的json数组末尾追加val。如果指定的路径是一个json对象,它将被封装到一个json数组中并被追加。如果参数为NULL,则返回NULL。

SET @ j4 = & # 8216[“一”, [“b & # 8221, “c & # 8221], “d & # 8221]’;

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

SET @ j5 = & # 8216{“一”: 1, “b & # 8221: [2, 3], “c & # 8221: 4}’;

SELECT JSON_ARRAY_APPEND(@j5,‘$.b & # 8217, ‘x & # 8217);—{“一”: 1, “b & # 8221: [2, 3, “x & # 8221], “c & # 8221: 4}

SELECT JSON_ARRAY_APPEND(@j5,‘$.c & # 8217, ‘y & # 8217);—{“一”: 1, “b & # 8221: [2, 3], “c & # 8221: [4, “y & # 8221]}

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

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

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

//在path指定的json数组元素中插入val,原位置和右边元素依次右移。如果path指定的数据不是json数组元素,这个val被忽略;如果指定的元素下标超过json数组的长度,则插入尾部。

SET @ j6 = & # 8216[“一”, {“b & # 8221: [1, 2]}, [3, 4]]’;

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

SELECT JSON_ARRAY_INSERT(@j6,‘$//替换指定路径的数据。如果路径不存在,跳过它(仅当它存在时替换它)。如果参数为NULL,则返回NULL。’, ‘x & # 8217);—[“一”, {“b & # 8221: [1, 2]}, [3, 4], “x & # 8221]

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

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

三。JSON_INSERT在指定位置插入

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

//在指定路径下插入数据。如果路径已经存在,忽略这个val(仅当它不存在时插入)。

SET @ j7 = & # 8216{ “一”: 1, “b & # 8221: [2, 3]}’;

SELECT JSON_INSERT(@j7,‘$.一’, 10, ‘$.c & # 8217, ‘[对,错]’);—{“一”: 1, “b & # 8221: [2, 3], “c & # 8221: “[对,错]”}

四。JSON_REPLACE指定要替换的位置

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

[100]

SELECT JSON_REPLACE(@j7,‘$.一’, 10, ‘$.c & # 8217, ‘[对,错]’);—{“一”: 10, “b & # 8221: [2, 3]}

V. JSON_SET指定位置设置

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

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

SELECT JSON_SET(@j7,‘$.一’, 10, ‘$.c & # 8217, ‘[对,错]’);—{“一”: 10, “b & # 8221: [2, 3], “c & # 8221: “[对,错]”}

六。JSON_MERGE Merge

//JSON_MERGE(json_doc,json_doc[,JSON _ doc]…)

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

//如果都是json数组,结果自动合并成一个json array

//如果都是json对象,结果自动合并成一个json objects

//如果有多种类型,按照规则一把非json数组元素打包成json数组和mege。

SELECT JSON _ MERGE(‘[1, 2]’, ‘[对,错]’);—[1,2,对,错]

SELECT JSON _ MERGE(‘{“姓名”: “x & # 8221}’, ‘{“id & # 8221: 47}’);—{“id & # 8221: 47, “姓名”: “x & # 8221}

SELECT JSON _ MERGE(‘1’, ‘真’);—[1,正确]

SELECT JSON _ MERGE(‘[1, 2]’, ‘{“id & # 8221: 47}’);—[1, 2, {“id & # 8221: 47}]

七。JSON_REMOVE指定要删除的位置

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

//删除指定路径的数据,如果不存在则跳过一个路径。如果参数为NULL,则返回NULL。

SET @ j8 = & # 8216[“一”, [“b & # 8221, “c & # 8221], “d & # 8221]’;

SELECT JSON_REMOVE(@j8,‘$[1]’);—[“一”, “d & # 8221]

八。JSON _ UNQUOTE to & # 8221编号

//JSON_UNQUOTE(val)

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

SELECT JSON _ un quote(“\”123\””);—123

返回json值属性的函数

一. JSON_DEPTH深度

//JSON_DEPTH(json_doc)

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

//空的json数组、json对象或标量的深度为1。

SELECT JSON _ DEPTH(‘{}’),JSON _ DEPTH(‘[]’),JSON _ DEPTH(‘真’);—1 1 1

SELECT JSON _ DEPTH(‘[10, 20]’),JSON _ DEPTH(‘[[], {}]’);—2 2

SELECT JSON _ DEPTH(‘[10, {“一”: 20}]’);—三

二。JSON_LENGTH长度

//JSON_LENGTH(json_doc[,path])

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

//长度的计算规则:

//标量的长度为1;

JSONArray的长度是元素的个数;

JSONObject的长度是键的个数。

SELECT JSON _ LENGTH(‘[1, 2, {“一”: 3}]’);—三

SELECT JSON _ LENGTH(‘{“一”: 1, “b & # 8221: {“c & # 8221: 30}}’);—2

SELECT JSON _ LENGTH(‘{“一”: 1, “b & # 8221: {“c & # 8221: 30}}’, ‘$.b & # 8217);—一个

三。JSON_TYPE类型

//JSON_TYPE(json_val)

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

select JSON _ TYPE(‘[1,2]’);—排列

四。json_VALID是json格式

//JSON_VALID(val)

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

SELECT JSON _ VALID(‘{“一”: 1}’);—一个

SELECT JSON _ VALID(‘你好’),JSON _ VALID(‘”你好”‘);—一个

附录:

函数名描述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值是否是有效的

温馨提示:内容均由网友自行发布提供,仅用于学习交流,如有版权问题,请联系我们。