MySQL之JSON类型字段怎么使用
今天小编给大家分享一下MySQL之JSON类型字段怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
测试环境: MySQL8.0.19
准备工作CREATETABLEjson_demo(`id`INT(11)NOTNULLPRIMARYKEY,`content`jsonNOTNULL);INSERTINTOjson_demo(id,content)VALUES/*这条是数组*/(1,'[{"key":1,"order":1,"value":"34252"},{"key":2,"order":2,"value":"23423"}]'),/*这条是数组*/(2,'[{"key":4,"order":4,"value":"234"},{"key":5,"order":5,"value":"234324523"}]'),/*这条是对象*/(3,'{"key":3,"order":3,"value":"43242"}'),/*这条是对象*/(4,'{"key":6,"order":6,"value":"5423"}');JSON对象基础操作
查询指定字段值
/*基础查询*/SELECTcontent->'$.key'AS'key',JSON_EXTRACT(content,'$.key')AS'key2',content->'$.value'AS'value',JSON_EXTRACT(content,'$.value')AS'value2',content->>'$.value'AS'value3',JSON_UNQUOTE(JSON_EXTRACT(content,'$.value'))AS'value4'FROMjson_demoWHEREid>2;
TIPS:
->和->>是MySQL设计的语法,其中->在MySQL5.7支持,->>在MySQL8.0中支持。
->等效于JSON_EXTRACT(),当查询字段为字符串时,其返回值还会带有""。
->>等效于JSON_UNQUOTE(JSON_EXTRACT()),当查询字段为字符串时,其返回值不会带有""。
用于条件查询
content -> '$.key'可以看成一个字段,一个字段能做的操作基本他都能。
SELECTid,content->'$.key'AS'key',content->>'$.value'AS'value3'FROMjson_demoWHEREid>2ANDcontent->'$.key'>1ANDcontent->'$.value'like'%2%';
修改指定字段值
/*修改*/UPDATEjson_demoSETcontent=JSON_REPLACE(content,/*将content.key值+1*/'$.key',content->'$.key'+1,/*将content.value值后拼接'abc'*/'$.value',concat(content->>'$.value','abc'))WHEREid=3;/*JSON_SET也可以*/UPDATEjson_demoSETcontent=JSON_SET(content,/*将content.key值+1*/'$.key',content->'$.key'+1,/*将content.value值后拼接'abc'*/'$.value',concat(content->>'$.value','abc'))WHEREid=3;/*查询修改结果*/SELECTid,content,content->'$.key'AS'key',content->>'$.value'AS'value3'FROMjson_demoWHEREid=3;/*重新赋值*/UPDATEjson_demoSETcontent=JSON_REPLACE(content,'$.key',3,'$.value','43242')WHEREid=3;
TIPS:
JSON_REPLACE和JSON_SET都可以用来修改某个字段值,区别在于JSON_REPLACE替换不存在的属性时操作无效;而JSON_SET则会将这个不存在的属性插入进去。
所以JSON_SET也可以用来追加属性,与JSON_INSERT类似。区别在于JSON_INSERT如果插入一个已存在的属性时操作会失效,而JSON_SET会替换。
追加元素
UPDATEjson_demoSETcontent=JSON_INSERT(content,'$.key',234)WHEREid=3;SELECTid,content,content->'$.key'AS'key'FROMjson_demoWHEREid=3;UPDATEjson_demoSETcontent=JSON_INSERT(content,'$.temp',234)WHEREid=3;SELECTid,content,content->'$.key'AS'key'FROMjson_demoWHEREid=3;UPDATEjson_demoSETcontent=JSON_SET(content,'$.temp2',432)WHEREid=3;SELECTid,content,content->'$.key'AS'key'FROMjson_demoWHEREid=3;
JSON数组操作查询指定字段值
SELECTid,content->'$[*].key'AS'key',content->>'$[*].value'AS'value',content->'$[0].key'AS'key2',content->>'$[0].value'AS'value2',/*查询数组长度*/JSON_LENGTH(content)AS'length'FROMjson_demoWHEREid<3;
用于条件查询
SELECTid,content->'$[*].key'AS'key',content->>'$[*].value'AS'value'FROMjson_demoWHEREid<3/*content.value的值中存在like'%34%'的值*/ANDcontent->>'$[*].value'like'%34%'/*content.key的值中有4*/ANDJSON_OVERLAPS(content->>'$[*].key','4');
修改指定字段值
基础操作都跟JSON对象差不太多,就是在'$'后面加对应的索引位'$[0]',指定所有则'$[*]'。如果数组中包含数组,可以通过'$[1][2][3]'这种方式指定深层的数组元素。
追加元素
JSON_ARRAY_APPEND和JSON_ARRAY_INSERT都可以实现数组元素追加。区别在于JSON_ARRAY_APPEND可以不指定索引位,此时往最后位置追加;JSON_ARRAY_INSERT必须指定索引位,不指定则会报错。
JSON_ARRAY_APPEND是追加在指定索引位后面,而JSON_ARRAY_INSERT则是插入到指定索引位前面。
更多操作以上就是“MySQL之JSON类型字段怎么使用”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注亿速云行业资讯频道。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。