欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2017年01月01日 14:29:25   作者:yangfei001  
MySQL 5.7.7 labs版本開始InnoDB存儲引擎已經(jīng)原生支持JSON格式,該格式不是簡單的BLOB類似的替換。下面我們來詳細探討下吧

MySQL5.7版本開始支持JSON格式,在創(chuàng)建表時,可以指定列表的數(shù)據(jù)類型為JSON,但是如何在JSON格式上創(chuàng)建索引呢??

本人做了一個簡單測試。

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

CREATE TABLE json_test` (
 id` int (8) NOT NULL AUTO_INCREMENT,
 content` json NOT NULL ,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

第二步:初始化數(shù)據(jù)

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類列的數(shù)據(jù)

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

通過expain分析改查詢語句,發(fā)現(xiàn)其走全表掃描

在網(wǎng)上查詢資料,得知如果要在JSON列上進行檢索,需要對檢索的key創(chuàng)建虛擬列,然后再虛擬列上創(chuàng)建索引

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

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

第五步:對虛擬列創(chuàng)建索引

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通過一種空間換時間的做法,類似創(chuàng)建一個觸發(fā)器,把JSON列上的數(shù)據(jù)冗余存儲到虛擬列上,比較的時候通過走虛擬列的索引,再定位到實際數(shù)據(jù)。

相關文章

  • 淺談SQLite時間函數(shù)的使用說明與總結分析

    淺談SQLite時間函數(shù)的使用說明與總結分析

    本篇文章是對SQLite時間函數(shù)的使用進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • MySQL字符集亂碼及解決方案分享

    MySQL字符集亂碼及解決方案分享

    這篇文章主要給大家介紹了關于MySQL字符集亂碼及解決方案的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用MySQL具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-04-04
  • CentOS7下mysql 8.0.16 安裝配置方法圖文教程

    CentOS7下mysql 8.0.16 安裝配置方法圖文教程

    這篇文章主要為大家詳細介紹了CentOS7下mysql 8.0.16 安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-05-05
  • MySQL常見的腳本語句格式參考指南

    MySQL常見的腳本語句格式參考指南

    無論是運維、開發(fā)、測試,還是架構師,數(shù)據(jù)庫技術是一個必備加薪神器,下面這篇文章主要給大家介紹了關于MySQL常見的腳本語句格式參考指南的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-06-06
  • MySQL外鍵創(chuàng)建失敗1005原因匯總

    MySQL外鍵創(chuàng)建失敗1005原因匯總

    MySQL外鍵創(chuàng)建失敗1005原因有很多,本文整理了一些,希望對大家有所幫助
    2014-01-01
  • MySQL 數(shù)據(jù)查重、去重的實現(xiàn)語句

    MySQL 數(shù)據(jù)查重、去重的實現(xiàn)語句

    這篇文章主要介紹了MySQL 數(shù)據(jù)查重、去重的實現(xiàn)語句,幫助大家更好的理解和學習MySQL數(shù)據(jù)庫,感興趣的朋友可以了解下
    2020-09-09
  • mysql 分頁優(yōu)化解析

    mysql 分頁優(yōu)化解析

    似乎討論分頁的人很少,難道大家都沉迷于limit m,n?在有索引的情況下,limit m,n速度足夠,可是在復雜條件搜索時,where somthing order by somefield+somefieldmysql會搜遍數(shù)據(jù)庫,找出“所有”符合條件的記錄,然后取出m,n條記錄。
    2008-04-04
  • MySQL主從同步延遲原因與解決方案

    MySQL主從同步延遲原因與解決方案

    本文主要介紹了MySQL主從同步延遲原因與解決方案,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-11-11
  • centos7環(huán)境下二進制安裝包安裝 mysql5.6的方法詳解

    centos7環(huán)境下二進制安裝包安裝 mysql5.6的方法詳解

    這篇文章主要介紹了centos7環(huán)境下二進制安裝包安裝 mysql5.6的方法,詳細分析了centos7環(huán)境下使用二進制安裝包安裝 mysql5.6的具體步驟、相關命令、配置方法及操作注意事項,需要的朋友可以參考下
    2020-02-02
  • mysql 索引的基礎操作匯總(四)

    mysql 索引的基礎操作匯總(四)

    這篇文章主要為大家詳細介紹了mysql 索引的基礎操作匯總,涵蓋了創(chuàng)建和查看索引、刪除索引等操作,感興趣的小伙伴們可以參考一下
    2016-08-08

最新評論