1. 程式人生 > >簡單談談MySQL5.7 JSON格式檢索

簡單談談MySQL5.7 JSON格式檢索

MySQL 5.7.7 labs版本開始InnoDB儲存引擎已經原生支援JSON格式,該格式不是簡單的BLOB類似的替換。下面我們來詳細探討下吧

MySQL5.7版本開始支援JSON格式,在建立表時,可以指定列表的資料型別為JSON,但是如何在JSON格式上建立索引呢??

本人做了一個簡單測試。

第一步:建立一個包含JSON型別的表:

CREATE TABLE json_test` (

 id` int (8) NOT NULL AUTO_INCREMENT,

 content` json NOT NULL ,

 PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

第二步:初始化資料

insert into json_test(content) value( '{"name":"zhangsan","age":18}' );
insert into json_test(content) value( '{"name":"lisi","age":19}' );
insert into json_test(content) value( '{"name":"wangwu","age":20}' );

第三步:查詢JSON類列的資料

select json_extract(content,  '$.name' )  from json_test  where json_extract(content,  '$.name' )= "zhangsan" ;

通過expain分析改查詢語句,發現其走全表掃描

在網上查詢資料,得知如果要在JSON列上進行檢索,需要對檢索的key建立虛擬列,然後再虛擬列上建立索引

第四步:在content列上,對"name"建立虛擬列

ALTER TABLE json_test  ADD name_virtual  varchar (32) GENERATED ALWAYS  AS (json_extract(content,  '$.name' )) VIRTUAL;

第五步:對虛擬列建立索引

CREATE INDEX name_virtual_index  ON json_test(name_virtual);

再次做查詢( 注,where條件需要使用虛擬列來進行檢索,如果直接用JSON列比較,還是會走全表掃描 )

explain  select json_extract(content,  '$.name' )  from json_test  where name_virtual= "zhangsan" \G

總結:

其實MySQL通過一種空間換時間的做法,類似建立一個觸發器,把JSON列上的資料冗餘儲存到虛擬列上,比較的時候通過走虛擬列的索引,再定位到實際資料。