mySQL中的JSON操作

2019-03-20  本文已影响0人  咖A喱

关于JSON值

[10,null,"a",true]
{"key1":"value1","key2":8}
["15:51:29.000000", "2019-03-20", "2019-043-20 15:51:29.000000"]
["ac",{"key1":"value1"}]
{"key2":10,[null,true]}

mySQL中的创建JSON值的函数

JSON_ARRAY([value[,value]…)
SELECT JSON_ARRAY(9,null,true,"I am Dolores",now());
//output
[9, null, true, "I am Dolores", "2019-03-20 16:05:42.000000"]
JSON_ARRAYAGG(value)

创建单个json数组

 SELECT JSON_ARRAYAGG(1);//[1]
 SELECT JSON_ARRAYAGG(null);//[null]
 SELECT JSON_ARRAYAGG(true);//[true]
 SELECT JSON_ARRAYAGG(now());//["2019-03-20 16:31:20.000000"]
JSON_OBJECT([key,value[,key,value]…)
SELECT json_object('name','Dolores','id','2015214328');
//output
{"id": "2015214328", "name": "Dolores"}
JSON_OBJECTAGG(key,value)

创建单个对象,并返回该对象

SELECT json_objectagg('ID',22);
//{"ID": 22}
JSON_QUOTE(string)
SELECT JSON_QUOTE('null');
//output
"null"

SELECT JSON_QUOTE('"null"');
//output
"\"null\""

SELECT JSON_QUOTE('I \'m Dolores');
//output
"I 'm Dolores"

SELECT JSON_QUOTE('[1,2,3]');
//output
"[1,2,3]"
CAST(value AS JSON)

将其他类型的值转换成JSON类型来获取json值

SELECT CAST('null' AS JSON)
//"null"

判断JSON

JSON_TYPE()

json值作为参数传入,如果值有效,则返回其json类型,否则报错

SELECT JSON_TYPE('[1,"Dolores",true]');
//ARRAY

SELECT JSON_TYPE('"hello"');
//STRING

SELECT JSON_TYPE('{"key":"value"}');
//OBJECT

SELECT JSON_TYPE('hello');
//Error Code: 3141. Invalid JSON text in argument 1 to function json_type: "Invalid value." at position 0.  0.000 sec

合并JSON

JSON_MERAGE_PRESERVE()

将两个或多个json值合并为一个json并返回最终值

SELECT JSON_MERGE_PRESERVE('["ABC","HELLO"]','{"name":"Dolores"}');
//["ABC", "HELLO", {"name": "Dolores"}]
JSON_MERGE_PATCH()

合并两个或多个json值,但不合并重复键的值,如果出现重复键,仅保留最后一个的值

SELECT JSON_MERGE_PATCH('[1, 2]', '[true, false]');
//[true, false]     

SELECT JSON_MERGE_PATCH('{"name": "x"}', '{"id": 47}');
//{"id": 47, "name": "x"}

SELECT JSON_MERGE_PATCH('{"a":{"x":1}}', '{"a":{"y":2}}');
// {"a": {"x": 1, "y": 2}}

两者的比较
SET @x = '{ "a": 1, "b": 2 }',
@y = '{ "a": 3, "c": 4 }',
@z = '{ "a": 5, "d": 6 }';

SELECT  JSON_MERGE_PATCH(@x, @y, @z)  AS `Patch`,
JSON_MERGE_PRESERVE(@x, @y, @z) AS `Preserve`
//Patch: {"a": 5, "b": 2, "c": 4, "d": 6}
//Preserve: {"a": [1, 3, 5], "b": 2, "c": 4, "d": 6}
mysql中的json是否区分大小写

经过函数转换得到的json是区分大小写的,原因在于转换后的字符集格式为utf8mb4utf8mb4_bin,因为utf8mb4_bin是二进制排序规则,所以区分大小写

SET @j = JSON_OBJECT('key', 'value');
SELECT CHARSET(@j), COLLATION(@j);
//utf8mb4     utf8mb4_bin   
SELECT JSON_ARRAY('a') = JSON_ARRAY('A');
//0
(0为false的意思)

因为区分大小写,所以json中的nulltruefalse都必须用小写字母编写

SELECT JSON_VALID('null'), JSON_VALID('Null'), JSON_VALID('NULL');
//1 0 0 

SELECT JSON_VALID('true'), JSON_VALID('True'), JSON_VALID('TRUE');
/1 0 0 

需要存储转义字符时

直接插入键值对语句和用JSON_OBJECT转换成json值存入的差别在于,前者需要双反斜杠转义字符,而后者只需要单反斜杠转义字符

CREATE TABLE facts (sentence JSON);

当需要存储的内容如下

mascot: The MySQL mascot is a dolphin named "Sakila".

使用直接插入的方法时:

INSERT INTO facts VALUES
('{"mascot": "Our mascot is a dolphin named \\"Sakila\\"."}');

SELECT sentence FROM facts;
// {"mascot": "Our mascot is a dolphin named \"Sakila\"."}

使用JSON_OBJECT

 INSERT INTO facts VALUES
(JSON_OBJECT("mascot", "Our mascot is a dolphin named \"Sakila\"."));

SELECT sentence FROM facts;
//{"mascot": "Our mascot is a dolphin named \"Sakila\"."}

搜索和修改json---json路径表达式

json路径表达式用于精确查找json中的值

案例

[3, {"a": [5, 6], "b": 10}, [99, 100]]

因为$[1]$[2]计算为非标量值, 所以它们可以用作选择嵌套值的更具体的路径表达式的基础。例子:

{"a fish": "shark", "a bird": "sparrow"}

结合JSON_SET``JSON_INSERT``JSON_REPLACE``JSON_REMOVE的使用

SET @j = '["a", {"b": [true, false]}, [10, 20]]';

JSON_SET替换存在的路径的值, 并为不存在的路径添加值

SELECT JSON_SET(@j, '$[1].b[0]', 1, '$[2][2]', 2);
// ["a", {"b": [1, false]}, [10, 20, 2]]

JSON_INSERT添加新值, 但不替换现有值:

SELECT JSON_INSERT(@j, '$[1].b[0]', 1, '$[2][2]', 2);
// ["a", {"b": [true, false]}, [10, 20, 2]] 

JSON_REPLACE替换现有值并忽略新值:

 SELECT JSON_REPLACE(@j, '$[1].b[0]', 1, '$[2][2]', 2);
 // ["a", {"b": [1, false]}, [10, 20]]  

JSON_REMOVE使用一个或多个路径, 这些路径指定要从文档中删除的值。返回值是原始文档减去由文档中存在的路径选择的值:

SELECT JSON_REMOVE(@j, '$[2]', '$[1].b[1]', '$[1].b[1]');
//["a", {"b": [true]}] 
上一篇 下一篇

猜你喜欢

热点阅读