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

溫馨提示×

溫馨提示×

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

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

SQL優化之多表關聯查詢-案例一

發布時間:2020-08-07 23:56:11 來源:ITPUB博客 閱讀:166 作者:StevenBeijing 欄目:MySQL數據庫

慢SQL日志里看到一個三張表的關聯查詢,如下:

SELECT COUNT(1) 
FROM refund_order_item i, artisan a, user u 
WHERE u.userid = i.user_id
	AND a.artisan_id = i.artisan_id;

測試查詢時間:

mysql> SELECT COUNT(1) 
    -> FROM refund_order_item i, artisan a, user u 
    -> WHERE u.userid = i.user_id
    -> AND a.artisan_id = i.artisan_id;
+----------+
| COUNT(1) |
+----------+
|   260605 |
+----------+
1 row in set (2.30 sec)

查看執行計劃:

mysql> explain SELECT COUNT(1) 
    -> FROM refund_order_item i, artisan a, user u 
    -> WHERE u.userid = i.user_id
    -> AND a.artisan_id = i.artisan_id;
+----+-------------+-------+------------+--------+----------------------------+---------+---------+------------------+--------+----------+-------------+
| id | select_type       | table   | partitions   | type      | possible_keys        | key        | key_len | ref              | rows            | filtered | Extra       |
+----+-------------+-------+------------+--------+----------------------------+---------+---------+------------------+--------+----------+-------------+
|  1 | SIMPLE      | i      | NULL       | ALL     | idx_user_id,idx_artisan_id       | NULL    | NULL    | NULL             | 255599 |   100.00 | NULL        |
|  1 | SIMPLE      | a     | NULL       | eq_ref | PRIMARY                               | PRIMARY | 122   | hlj.i.artisan_id |      1     |   100.00 | Using index |
|  1 | SIMPLE      | u     | NULL       | eq_ref | userid                                    | userid    | 122      | hlj.i.user_id    |      1     |   100.00 | Using index |
+----+-------------+-------+------------+--------+----------------------------+---------+---------+------------------+--------+----------+-------------+

可以看到refund_order_item表沒有走索引。

創建聯合索引:

ALTER TABLE refund_order_item ADD INDEX idx_aid_uid (artisan_id, user_id);

查看執行計劃:

explain SELECT COUNT(1)  FROM refund_order_item i, artisan a, user u  WHERE u.userid = i.user_id AND a.artisan_id = i.artisan_id;
+----+-------------+-------+------------+--------+----------------------------------------+-------------+---------+------------------+--------+----------+-------------+
| id | select_type | table | partitions | type   | possible_keys                                  | key         | key_len | ref              | rows   | filtered | Extra       |
+----+-------------+-------+------------+--------+----------------------------------------+-------------+---------+------------------+--------+----------+-------------+
|  1 | SIMPLE      | i      | NULL       | index  | idx_user_id,idx_artisan_id,idx_aid_uid | idx_aid_uid | 244     | NULL             | 255599 |   100.00 | Using index |
|  1 | SIMPLE      | a     | NULL       | eq_ref | PRIMARY                                           | PRIMARY     | 122     | hlj.i.artisan_id |      1 |   100.00 | Using index |
|  1 | SIMPLE      | u     | NULL       | eq_ref | userid                                                 | userid      | 122        | hlj.i.user_id    |      1 |   100.00 | Using index |
+----+-------------+-------+------------+--------+----------------------------------------+-------------+---------+------------------+--------+----------+-------------+

可以看到執行計劃已經走索引。

測試查詢時間:

mysql> SELECT COUNT(1) 
    -> FROM refund_order_item i, artisan a, user u 
    -> WHERE u.userid = i.user_id
    -> AND a.artisan_id = i.artisan_id;
+----------+
| COUNT(1) |
+----------+
|   260605 |
+----------+
1 row in set (1.15 sec)
向AI問一下細節

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

AI

科技| 巴里| 鹿泉市| 历史| 台中县| 施秉县| 夏邑县| 丹寨县| 富锦市| 天津市| 麻江县| 耿马| 齐齐哈尔市| 石河子市| 嘉定区| 金沙县| 佛教| 芷江| 花莲县| 富川| 内丘县| 姜堰市| 广德县| 贵南县| 遵化市| 镇沅| 信宜市| 樟树市| 深圳市| 南召县| 三明市| 灵石县| 和政县| 竹溪县| 牡丹江市| 外汇| 驻马店市| 滦南县| 云阳县| 大名县| 泗阳县|