91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL SQL優化 - 覆蓋索引(covering index)

發布時間:2020-08-08 00:29:26 來源:ITPUB博客 閱讀:184 作者:jichengjie 欄目:MySQL數據庫
CREATE TABLE `user_group` (
  `id` int(11) NOT NULL auto_increment,
  `uid` int(11) NOT NULL,
  `group_id` int(11) NOT NULL,
  PRIMARY KEY  (`id`),
  KEY `uid` (`uid`),
  KEY `group_id` (`group_id`),
) ENGINE=InnoDB AUTO_INCREMENT=750366 DEFAULT CHARSET=utf8 

看AUTO_INCREMENT就知道數據并不多,75萬條。簡單的查詢:

SELECT SQL_NO_CACHE uid FROM user_group WHERE group_id = 245;   
-- SQL_NO_CACHE 不使用緩存提示

Explain的結果是:
+----+-------------+------------+------+---------------+----------+---------+-------+------+-------+
| id | select_type | table      | type | possible_keys | key      | key_len | ref   | rows | Extra |
+----+-------------+------------+------+---------------+----------+---------+-------+------+-------+
|  1 | SIMPLE      | user_group | ref  | group_id      | group_id | 4       | const | 5544 |       |
+----+-------------+------------+------+---------------+----------+---------+-------+------+-------+

看起來已經用上索引了,數據分布上,group_id相同的比較多,uid散列的比較均勻,加索引的效果一般,試著加了一個多列索引:
ALTER TABLE user_group ADD INDEX group_id_uid (group_id, uid);

這句SQL查詢的性能發生了巨大的提升,居然已經可以跑到0.00s左右了。經過優化的SQL再結合真實的業務需求,也從之前2.2s下降到0.05s。
再Explain一次
+----+-------------+------------+------+-----------------------+--------------+---------+-------+------+-------------+
| id | select_type | table      | type | possible_keys         | key          | key_len | ref   | rows | Extra       |
+----+-------------+------------+------+-----------------------+--------------+---------+-------+------+-------------+
|  1 | SIMPLE      | user_group | ref  | group_id,group_id_uid | group_id_uid | 4       | const | 5378 | Using index |
+----+-------------+------------+------+-----------------------+--------------+---------+-------+------+-------------+

這種叫覆蓋索引(covering index),MySQL只需要通過索引就可以返回查詢所需要的數據,而不必在查到索引之后再去查詢數據,所以相當快!!但是同時也要求所查詢的字段必須被索引所覆蓋到,在Explain的時候,輸出的Extra信息中如果有“Using Index”,就表示這條查詢使用了覆蓋索引。
向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

上林县| 正阳县| 上高县| 乌兰县| 旬阳县| 梓潼县| 长丰县| 灌云县| 陈巴尔虎旗| 义乌市| 库车县| 珠海市| 抚宁县| 张家界市| 五台县| 佛山市| 凯里市| 泰宁县| 大埔县| 句容市| 邳州市| 漳平市| 玉山县| 余干县| 新乡县| 饶河县| 淮安市| 墨江| 弥渡县| 甘谷县| 南部县| 咸丰县| 华安县| 基隆市| 开阳县| 监利县| 齐齐哈尔市| 郓城县| 冀州市| 江油市| 扎鲁特旗|