经过漫长的测试,即将整体迁移至Mysql8.0; Mysql8.0 对于Json操作新增/优化了很多相关Json的API操作。
阅读了一下官方文档,虽然绝大多数的JSON操作都是应用层完成,但是会一些Mysql的JSON语法,方便进行debug;选出基础的, 有价值的部分,供未来参考;
https://dev.mysql.com/doc/refman/8.0/en/json.html https://dev.mysql.com/doc/refman/8.0/en/json-utility-functions.html
简单概述
-
不允许为null; Json格式定义与LONGBLOB or LONGTEXT类似;它的最大长度是受到max_allowed_packet所控制的; -
查看JSON字段所占用空间大小的函数时JSON_STORAGE_SIZE(xxx); -
除普通的Json操作,额外支持GeoJSON (基于几何图形的针对地理空间数据交换格式)一些相关操作; -
对Json栏位支持索引(结合Mysql8.0新特性,函数index); -
一个可以支持部分的,原地更新Json Column 的可选优化项加入MySql8.0; 可以使用的函数有JSON_SET(), JSON_REPLACE() ,JSON_REMOVE(); 使用时,有一些约束,但是会有更加的性能;
JSON基础工具;
;
合并JSON的操作 JSON_MERGE_PRESERVE()
and JSON_MERGE_PATCH()
实际业务用的可能性很少;
-> -->操作符,按照key 找值;区别在于 -->会去除包裹的”以及转义符号; 它的等价的Function形式是JSON_EXTRACT()
JSON Path expression上面 --> 后双引号中的内容就是所谓的JSON Path expression; 该语法是ECMAScript规范的一部分,所以前端程序员应该特别熟悉。
最新 MySQL 面试题整理推荐看下这篇:http://www.javastack.cn/mst/
以下面这段JSON为例;
: 10};
$[2] = [99, 100];
与此同时,[2] 并非标量, 进一步
$[1].a = [5,6]
$[1].a[1] = 6
$[1].b = 10;
$[2][0] = 99;
更进一步支持的语法特性$[n to m]
: 10}]
总结一下;
a .是代表所有的members in object; b []是代表所有的cells in array; c [prefix] ** suffix 是代表以prefix开始,以suffix为结束的所有路径;另外,MySQL 系列面试题和答案全部整理好了,微信搜索Java技术栈,在后台发送:面试,可以在线阅读。
查找并修改JSON
JSON Table Functions 一个比较常见的场景是JSON数据本身是一个表的结构;JSON_TABLE(*
expr*, *
path* COLUMNS (*
column_list*) [AS] *
alias*)
-> )
-> ) AS tt;
-
Comparison and Ordering of JSON Values目前没感觉倒价值; -
Aggregation of JSON Values目前没感觉倒价值; 将返回值转成其他类型就可以使用聚合函数;
本文为原创文章,版权归知行编程网所有,欢迎分享本文,转载请保留出处!
你可能也喜欢
- ♥ 2020世界年轻大学排名发布:中国高校蝉联世界第一!05/09
- ♥ 有了这 27 个Linux 技巧,让你工作效率翻倍!07/14
- ♥ 如何退出python帮助11/06
- ♥ 爬虫实战 | 用Python爬取指定关键词的微博~07/13
- ♥ python导出csv中文乱码12/20
- ♥ python偏函数是什么?以及代码实现方法10/01
内容反馈