mysql支持json索引_MySQL 5.7新支持--------Json索引创建实战

1. 背景

* 在MySQL 5.7.8中,MySQL支持由RFC 7159定义的本地JSON数据类型,它支持对JSON(JavaScript对象标记)文档中的数据进行有效访问.

* MySQL会对DML JSON数据自动验证。无效的DML JSON数据操作会产生错误.

* 优化的存储格式。存储在JSON列中的JSON文档转换为一种内部格式,允许对Json元素进行快速读取访问.

* MySQL Json类型支持通过虚拟列方式建立索引,从而增加查询性能提升.

2. Json 索引

* 创建Json索引表 json_key [ name 为虚拟列, virtual 表明不占用磁盘空间 ]

[ GENERATED ALWAYS 与 VIRTUAL可以不写 ]

指定获取json中的name keymysql> CREATE TABLE json_key(

-> uid BIGINT PRIMARY KEY NOT NULL AUTO_INCREMENT,

-> data JSON NOT NULL,

-> name VARCHAR(32) GENERATED ALWAYS AS (json_extract(data, ‘$.name‘)) VIRTUAL,

-> )ENGINE=INNODB CHARSET=utf8mb4;

* 插入数据带 data中name key [ 插入数据时需要显示指定非虚拟列 ]mysql> INSERT INTO json_key(uid, data) SELECT NULL, JSON_OBJECT(‘name‘, ‘tom‘, ‘sex‘, ‘male‘, ‘age‘, ‘26‘);

Query OK, 1 row affected (0.02 sec)

Records: 1  Duplicates: 0  Warnings: 0

* 插入数据不带 data中name keymysql> INSERT INTO json_key(uid, data) SELECT NULL, JSON_OBJECT(‘sex‘, ‘female‘, ‘age‘, ‘29‘);

Query OK, 1 row affected (0.01 sec)

Records: 1  Duplicates: 0  Warnings: 0

* 查看json_key所有数据mysql> select * from json_key;

+-----+---------------------------------------------+-------+

| uid | data                                        | name  |

+-----+---------------------------------------------+-------+

|   1 | {"age": "26", "sex": "male", "name": "tom"} | "tom" |

|   2 | {"age": "29", "sex": "female"}              | NULL  |

+-----+---------------------------------------------+-------+

2 rows in set (0.01 sec)

4. 总结

以需求驱动技术,技术本身没有优略之分,只有业务之分。

原文:http://lisea.blog.51cto.com/5491873/1943389

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值