JSON類型 和 生成列 - 非官方 MySQL 8.0 優(yōu)化指南 - 學(xué)習(xí)筆記

MySQL Server 支持無模式的數(shù)據(jù)存儲(chǔ)菲茬,功能特性如下:

  1. JSON 數(shù)據(jù)類型娱俺。JSON 值在新增 / 更新時(shí)會(huì)被分析、驗(yàn)證刷晋,然后儲(chǔ)存為優(yōu)化了的二進(jìn)制格式盖高。在讀取時(shí)不需任何分析或驗(yàn)證。
  2. JSON 函數(shù)眼虱。有 20 多個(gè) SQL 函數(shù)用于搜索喻奥、操作、創(chuàng)建 JSON 值捏悬。
  3. 生成列撞蚕。其工作方式很像函數(shù)索引,并能夠?qū)?JSON 的一部分進(jìn)行提取或索引过牙。

優(yōu)化器在查詢 JSON 數(shù)據(jù)時(shí)甥厦,會(huì)自動(dòng)通過生成列尋找匹配的索引。
在例子35中寇钉,“用戶設(shè)置” 被儲(chǔ)存在了JSON列中刀疙,查詢 “更新時(shí)通知我” 的用戶,會(huì)使用全表掃描扫倡。通過增加一個(gè)虛擬生成列谦秧,EXPLAIN 展示出能使用到索引了:

例子35:“用戶設(shè)置” 的無模式表示法

CREATE TABLE users (
  id INT NOT NULL auto_increment,
  username VARCHAR(32) NOT NULL,
  preferences JSON NOT NULL,      -- “用戶設(shè)置” 使用了 JSON 類型
  PRIMARY KEY (id),
  UNIQUE (username)
);

INSERT INTO users
 (id,username,preferences)
VALUES
 (NULL, 'morgan', '{"layout": "horizontal", "warn_before_delete": false, "notify_on_updates": true}'),
 (NULL, 'wes', '{"layout": "horizontal", "warn_before_delete": false, "notify_on_updates": false}'),
 (NULL, 'jasper', '{"layout": "horizontal", "warn_before_delete": false, "notify_on_updates": false}'),
 (NULL, 'gus', '{"layout": "horizontal", "warn_before_delete": false, "notify_on_updates": false}'),
 (NULL, 'olive', '{"layout": "horizontal", "warn_before_delete": false, "notify_on_updates": false}');

EXPLAIN FORMAT=JSON 
SELECT * FROM users WHERE preferences->"$.notify_on_updates" = true;
{
  "query_block": {
    "select_id": 1,
    "cost_info": {
      "query_cost": "2.00"
    },
    "table": {
      "table_name": "users",          
      "access_type": "ALL",         # 查詢 “用戶設(shè)置” 時(shí),使用了全表掃描
      "rows_examined_per_scan": 5,
      "rows_produced_per_join": 5,
      "filtered": "100.00",
      "cost_info": {
        "read_cost": "1.00",
        "eval_cost": "1.00",
        "prefix_cost": "2.00",
        "data_read_per_join": "280"
      },
      "used_columns": [
        "id",
        "username",
        "preferences"
      ],
      "attached_condition": "(json_extract(`test`.`users`.`preferences`,'$.notify_on_updates') = TRUE)"
    }
  }
}

例子36:添加虛擬生成列

-- 添加虛擬列。注意 JSON類型 訪問和修改的語法疚鲤。
ALTER TABLE users 
  ADD notify_on_updates TINYINT AS (preferences->"$.notify_on_updates"),
  ADD INDEX(notify_on_updates);

EXPLAIN FORMAT=JSON 
SELECT * FROM users WHERE preferences->"$.notify_on_updates" = true;
{
  "query_block": {
    "select_id": 1,
    "cost_info": {
      "query_cost": "1.20"
    },
    "table": {
      "table_name": "users",    
      "access_type": "ref",         # 使用到了索引
      "possible_keys": [
        "notify_on_updates"
      ],
      "key": "notify_on_updates",
      "used_key_parts": [
        "notify_on_updates"
      ],
      "key_length": "2",
      "ref": [
        "const"
      ],
      "rows_examined_per_scan": 1,
      "rows_produced_per_join": 1,
      "filtered": "100.00",
      "cost_info": {
        "read_cost": "1.00",
        "eval_cost": "0.20",
        "prefix_cost": "1.20",
        "data_read_per_join": "56"
      },
      "used_columns": [
        "id",
        "username",
        "preferences",
        "notify_on_updates"
      ]
    }
  }
}

譯自:
JSON and Generated Columns - The Unofficial MySQL 8.0 Optimizer Guide

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末锥累,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子集歇,更是在濱河造成了極大的恐慌桶略,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,277評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件诲宇,死亡現(xiàn)場(chǎng)離奇詭異际歼,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)焕窝,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門蹬挺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人它掂,你說我怎么就攤上這事巴帮。” “怎么了虐秋?”我有些...
    開封第一講書人閱讀 163,624評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵榕茧,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我客给,道長(zhǎng)用押,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,356評(píng)論 1 293
  • 正文 為了忘掉前任靶剑,我火速辦了婚禮蜻拨,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘桩引。我一直安慰自己缎讼,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,402評(píng)論 6 392
  • 文/花漫 我一把揭開白布坑匠。 她就那樣靜靜地躺著血崭,像睡著了一般。 火紅的嫁衣襯著肌膚如雪厘灼。 梳的紋絲不亂的頭發(fā)上夹纫,一...
    開封第一講書人閱讀 51,292評(píng)論 1 301
  • 那天,我揣著相機(jī)與錄音设凹,去河邊找鬼舰讹。 笑死,一個(gè)胖子當(dāng)著我的面吹牛闪朱,可吹牛的內(nèi)容都是我干的月匣。 我是一名探鬼主播匈睁,決...
    沈念sama閱讀 40,135評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼桶错!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起胀蛮,我...
    開封第一講書人閱讀 38,992評(píng)論 0 275
  • 序言:老撾萬榮一對(duì)情侶失蹤院刁,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后粪狼,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體退腥,經(jīng)...
    沈念sama閱讀 45,429評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,636評(píng)論 3 334
  • 正文 我和宋清朗相戀三年再榄,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了狡刘。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,785評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡困鸥,死狀恐怖嗅蔬,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情疾就,我是刑警寧澤澜术,帶...
    沈念sama閱讀 35,492評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站猬腰,受9級(jí)特大地震影響鸟废,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜姑荷,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,092評(píng)論 3 328
  • 文/蒙蒙 一盒延、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧鼠冕,春花似錦添寺、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至楞捂,卻和暖如春薄坏,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背寨闹。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工胶坠, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人繁堡。 一個(gè)月前我還...
    沈念sama閱讀 47,891評(píng)論 2 370
  • 正文 我出身青樓沈善,卻偏偏與公主長(zhǎng)得像乡数,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子闻牡,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,713評(píng)論 2 354