亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > 文庫 > 正文

SQL優化案例分享--聯合索引

2024-09-07 22:12:32
字體:
來源:轉載
供稿:網友
       下面這個SQL如何優化:
 
      desc select count(*) as total from Art_Person a, Art_Works b where a.PersonCode=b.PersonCode;
 
+----+-------------+-------+-------+---------------+------------+---------+---------------------+--------+-------------+
 
      | id | select_type | table | type  | possible_keys | key        | key_len | ref                 | rows   | Extra       |
 
+----+-------------+-------+-------+---------------+------------+---------+---------------------+--------+-------------+
 
      |  1 | SIMPLE      | b     | index | PersonCode    | PersonCode | 25      | NULL                | 166904 | Using index |
 
      |  1 | SIMPLE      | a     | ref   | PersonCode    | PersonCode | 24      | newart.b.PersonCode |      1 | Using index |
 
+----+-------------+-------+-------+---------------+------------+---------+---------------------+--------+-------------+
 
2 rows in set (0.00 sec)
 
mysql> show profile for query 2;
 
+----------------------+----------+
 
| Status               | Duration |
 
+----------------------+----------+
 
| starting             | 0.000149 |
 
| checking permissions | 0.000015 |
 
| checking permissions | 0.000015 |
 
| Opening tables       | 0.000049 |
 
| System lock          | 0.000032 |
 
| init                 | 0.000065 |
 
| optimizing           | 0.000032 |
 
| statistics           | 0.000053 |
 
| preparing            | 0.000039 |
 
| executing            | 0.000019 |
 
| Sending data         | 2.244108 |
 
| end                  | 0.000042 |
 
| query end            | 0.000008 |
 
| closing tables       | 0.000023 |
 
| freeing items        | 0.000038 |
 
| logging slow query   | 0.000007 |
 
| logging slow query   | 0.000008 |
 
| cleaning up          | 0.000008 |
 
+----------------------+----------+
 
18 rows in set (0.00 sec)
 
mysql> show create table Art_Works/G
 
*************************** 1. row ***************************
 
Table: Art_Works
 
Create Table: CREATE TABLE `Art_Works` (
 
`PID` int(11) NOT NULL AUTO_INCREMENT,
 
PRIMARY KEY (`PID`),
 
KEY `ViewCount` (`ViewCount`),
 
KEY `PersonCode` (`PersonCode`) USING BTREE,
 
KEY `GoodsStatus` (`GoodsStatus`) USING BTREE,
 
KEY `CreateTime` (`CreateTime`) USING BTREE,
 
KEY `RelWorkID` (`RelWorkID`) USING BTREE
 
) ENGINE=MyISAM AUTO_INCREMENT=210549 DEFAULT CHARSET=utf8
 
mysql> show create table Art_Person/G
 
*************************** 1. row ***************************
 
Table: Art_Person
 
Create Table: CREATE TABLE `Art_Person` (
 
`PID` int(11) NOT NULL AUTO_INCREMENT,
 
PRIMARY KEY (`PID`),
 
UNIQUE KEY `MemberID` (`MemberID`),
 
KEY `PersonCode` (`PersonCode`) USING BTREE
 
) ENGINE=MyISAM AUTO_INCREMENT=8699 DEFAULT CHARSET=utf8
 
1 row in set (0.00 sec)
 
解決辦法(索引的問題):帶著主鍵,改成聯合索引。count() 的時候 帶上 主鍵 就ok了 不然不會走的。其實這個索引就是為了小表驅動大表,只是大表的索引 對count()而言 沒用。加上 主鍵 就可以了。
 
mysql> alter table Art_Person add index idx_PU(PersonCode,PID);帶著主鍵,改成聯合索引。
 
Query OK, 8666 rows affected (0.49 sec)
 
Records: 8666  Duplicates: 0  Warnings: 0
 
mysql> alter table Art_Works add index idx_PU(PersonCode,PID); 帶著主鍵,改成聯合索引。
 
Query OK, 166904 rows affected (6.02 sec)
 
Records: 166904  Duplicates: 0  Warnings: 0
 
mysql> desc  select sql_no_cache count(*) as total from Art_Works b,Art_Person a force index (PersonCode) where b.PersonCode=a.PersonCode;
 
+----+-------------+-------+-------+-------------------+------------+---------+---------------------+------+--------------------------+
 
| id | select_type | table | type  | possible_keys     | key        | key_len | ref                 | rows | Extra                    |
 
+----+-------------+-------+-------+-------------------+------------+---------+---------------------+------+--------------------------+
 
|  1 | SIMPLE      | a     | index | PersonCode        | PersonCode | 24      | NULL                | 8666 | Using index              |
 
|  1 | SIMPLE      | b     | ref   | PersonCode,idx_PU | idx_PU     | 25      | newart.a.PersonCode |    1 | Using where; Using index |
 
+----+-------------+-------+-------+-------------------+------------+---------+---------------------+------+--------------------------+
 
2 rows in set (0.00 sec)
 
下面是刪除索引,看看count(1)這么走。
 
mysql> alter table Art_Person drop index idx_PU ;
 
Query OK, 8666 rows affected (0.45 sec)
 
Records: 8666  Duplicates: 0  Warnings: 0
 
mysql> alter table Art_Works drop index idx_PU ;
 
Query OK, 166904 rows affected (3.90 sec)
 
Records: 166904  Duplicates: 0  Warnings: 0
 
mysql>  select sql_no_cache count(1) as total from Art_Works b,Art_Person a force index (PersonCode) where b.PersonCode=a.PersonCode;
 
+--------+
 
| total  |
 
+--------+
 
| 166657 |
 
+--------+
 
1 row in set (2.38 sec)
 
mysql> alter table Art_Works add index idx_PU(PersonCode,PID);
 
Query OK, 166904 rows affected (4.32 sec)
 
Records: 166904  Duplicates: 0  Warnings: 0
 
mysql>  select sql_no_cache count(1) as total from Art_Works b,Art_Person a force index (PersonCode) where b.PersonCode=a.PersonCode;
 
+--------+
 
| total  |
 
+--------+
 
| 166657 |
 
+--------+
 
1 row in set (0.44 sec)
 
mysql> desc select sql_no_cache count(1) as total from Art_Works b,Art_Person a force index (PersonCode) where b.PersonCode=a.PersonCode;
 
+----+-------------+-------+-------+-------------------+------------+---------+---------------------+------+--------------------------+
 
| id | select_type | table | type  | possible_keys     | key        | key_len | ref                 | rows | Extra                    |
 
+----+-------------+-------+-------+-------------------+------------+---------+---------------------+------+--------------------------+
 
|  1 | SIMPLE      | a     | index | PersonCode        | PersonCode | 24      | NULL                | 8666 | Using index              |
 
|  1 | SIMPLE      | b     | ref   | PersonCode,idx_PU | idx_PU     | 25      | newart.a.PersonCode |    1 | Using where; Using index |
 
+----+-------------+-------+-------+-------------------+------------+---------+---------------------+------+--------------------------+
 
2 rows in set (0.00 sec)
 
下面是去掉大表的索引:把大表的索引去掉  count(PersonCode) 也沒用,還是不走索引
 
mysql> alter table Art_Works drop index idx_PU ;
 
Query OK, 166904 rows affected (3.82 sec)
 
Records: 166904  Duplicates: 0  Warnings: 0
 
mysql> desc select sql_no_cache count(b.PersonCode) as total from Art_Works b,Art_Person a force index (PersonCode) where b.PersonCode=a.PersonCode;
 
+----+-------------+-------+-------+---------------+------------+---------+---------------------+--------+-------------+
 
| id | select_type | table | type  | possible_keys | key        | key_len | ref                 | rows   | Extra       |
 
+----+-------------+-------+-------+---------------+------------+---------+---------------------+--------+-------------+
 
|  1 | SIMPLE      | b     | index | PersonCode    | PersonCode | 25      | NULL                | 166904 | Using index |
 
|  1 | SIMPLE      | a     | ref   | PersonCode    | PersonCode | 24      | newart.b.PersonCode |     13 | Using index |
 
+----+-------------+-------+-------+---------------+------------+---------+---------------------+--------+-------------+
 
2 rows in set (0.00 sec)
 
mysql>  select sql_no_cache count(b.PersonCode) as total from Art_Works b,Art_Person a force index (PersonCode) where b.PersonCode=a.PersonCode;
 
+--------+
 
| total  |
 
+--------+
 
| 166657 |
 
+--------+
 
1 row in set (2.47 sec)
 
mysql> alter table Art_Works add index idx_PU(PersonCode,PID);
 
Query OK, 166904 rows affected (4.23 sec)
 
Records: 166904  Duplicates: 0  Warnings: 0
 
mysql>  select sql_no_cache count(b.PersonCode) as total from Art_Works b,Art_Person a force index (PersonCode) where b.PersonCode=a.PersonCode;
 
+--------+
 
| total  |
 
+--------+
 
| 166657 |
 
+--------+
 
1 row in set (0.44 sec)
 
=====================下面是線上實驗結果========================================
 
mysql> desc select sql_no_cache count(*) as total from Art_Works b,Art_Person a force index (PersonCode) where b.PersonCode=a.PersonCode;          
 
+----+-------------+-------+-------+---------------+------------+---------+---------------------+--------+-------------+
 
| id | select_type | table | type  | possible_keys | key        | key_len | ref                 | rows   | Extra       |
 
+----+-------------+-------+-------+---------------+------------+---------+---------------------+--------+-------------+
 
|  1 | SIMPLE      | b     | index | PersonCode    | PersonCode | 25      | NULL                | 173223 | Using index |
 
|  1 | SIMPLE      | a     | ref   | PersonCode    | PersonCode | 24      | newart.b.PersonCode |     13 | Using index |
 
+----+-------------+-------+-------+---------------+------------+---------+---------------------+--------+-------------+
 
2 rows in set (0.00 sec)
 
mysql>  alter table Art_Works add index idx_PU(PersonCode,PID);  
 
Query OK, 173223 rows affected (5.73 sec)
 
Records: 173223  Duplicates: 0  Warnings: 0
 
mysql> desc select sql_no_cache count(*) as total from Art_Works b,Art_Person a force index (PersonCode) where b.PersonCode=a.PersonCode;
 
+----+-------------+-------+-------+-------------------+------------+---------+---------------------+------+--------------------------+
 
| id | select_type | table | type  | possible_keys     | key        | key_len | ref                 | rows | Extra                    |
 
+----+-------------+-------+-------+-------------------+------------+---------+---------------------+------+--------------------------+
 
|  1 | SIMPLE      | a     | index | PersonCode        | PersonCode | 24      | NULL                | 8910 | Using index              |
 
|  1 | SIMPLE      | b     | ref   | PersonCode,idx_PU | idx_PU     | 25      | newart.a.PersonCode |    1 | Using where; Using index |
 
+----+-------------+-------+-------+-------------------+------------+---------+---------------------+------+--------------------------+
 
2 rows in set (0.00 sec)

(編輯:武林網)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品电影网在线观看| 日本免费一区二区三区视频观看| 日韩美女视频免费看| 久久色精品视频| 亚洲第一中文字幕在线观看| 日韩经典第一页| 亚洲国产一区二区三区在线观看| 中文字幕一精品亚洲无线一区| 亚洲国产欧美自拍| 91久热免费在线视频| 亚洲区中文字幕| 亚洲女人天堂av| 欧美wwwxxxx| 久久99视频精品| 亚洲人午夜色婷婷| 精品国产一区二区在线| 国产精品大陆在线观看| 成人黄色在线免费| 国产精品免费久久久| 久久久久久久一区二区| 久久影院在线观看| 日韩欧美一区二区三区| yw.139尤物在线精品视频| 久久天天躁狠狠躁夜夜躁| 成人免费高清完整版在线观看| 日韩精品亚洲精品| 欧美精品久久久久久久久久| 九九热这里只有精品6| 91产国在线观看动作片喷水| 亚洲free性xxxx护士白浆| 乱亲女秽乱长久久久| 亚洲在线观看视频| 黑人巨大精品欧美一区免费视频| 国产精品香蕉在线观看| 懂色aⅴ精品一区二区三区蜜月| 九九视频直播综合网| 91亚洲一区精品| 97香蕉超级碰碰久久免费的优势| 精品亚洲永久免费精品| 国产丝袜一区二区三区| 亚洲欧美第一页| 国产精品免费小视频| 亚洲奶大毛多的老太婆| 午夜精品理论片| 欧美诱惑福利视频| 国产香蕉一区二区三区在线视频| 色综合亚洲精品激情狠狠| 久久久久久国产三级电影| 日韩在线观看免费全| 成人黄色av网| 国产精品第100页| 国产精品91久久久| 亚洲女人天堂成人av在线| 亚洲欧美日韩国产成人| 精品国产老师黑色丝袜高跟鞋| 国产69精品久久久久9| 日韩电影网在线| 日韩精品高清视频| 亚洲欧美在线看| 国产主播在线一区| 色噜噜久久综合伊人一本| 欧美大片免费看| 欧美插天视频在线播放| 亚洲精品福利在线观看| 国产精品日韩在线观看| 欧美日韩国产激情| 欧美高清激情视频| 日本精品性网站在线观看| 日韩精品亚洲视频| 成人激情在线观看| 国产精品av免费在线观看| 国产精品成人在线| 中文字幕九色91在线| 国产精品国产三级国产专播精品人| 国产91成人video| 成人中文字幕在线观看| 亚洲一品av免费观看| 亚洲激情自拍图| 色偷偷9999www| 中文字幕视频一区二区在线有码| 性欧美在线看片a免费观看| 一二美女精品欧洲| 亚洲91av视频| 在线中文字幕日韩| 97视频在线观看亚洲| 96sao精品视频在线观看| 国a精品视频大全| 久久久久久久激情视频| 亚洲欧美日韩国产中文专区| 在线看国产精品| 国产成人在线一区二区| 欧美肥老太性生活视频| 91九色综合久久| 国产亚洲欧美日韩美女| 中文字幕不卡在线视频极品| 狠狠躁夜夜躁人人爽天天天天97| 美女扒开尿口让男人操亚洲视频网站| 最近更新的2019中文字幕| 国产亚洲欧洲在线| 欧美成人午夜免费视在线看片| 欧美成人午夜免费视在线看片| 日韩精品小视频| 久久综合国产精品台湾中文娱乐网| 日韩va亚洲va欧洲va国产| 亚洲色在线视频| 国产精品午夜一区二区欲梦| 精品中文视频在线| 国产精品久久久久久av福利| 96国产粉嫩美女| 日韩在线免费视频观看| 亚洲一区二区三区乱码aⅴ| 亚洲欧洲激情在线| 日韩欧美在线免费| 久久久久久久久久久网站| 久久中文字幕国产| 韩剧1988在线观看免费完整版| 国产一区二区三区三区在线观看| 亚洲精品久久久久久久久久久久| 成人精品一区二区三区电影黑人| 亚洲图中文字幕| 97国产一区二区精品久久呦| 亚洲欧美日韩天堂| 少妇高潮 亚洲精品| 日韩精品在线影院| 国产午夜精品免费一区二区三区| 国产日韩欧美夫妻视频在线观看| 日韩欧美黄色动漫| 国产一区二区三区在线视频| 日韩精品视频在线观看网址| 国产精品久久久久久久久久尿| 国产精品88a∨| 国产精品久久久久久久久久尿| 国产精品激情av在线播放| 久久久这里只有精品视频| 久久久久久国产免费| 中文字幕日韩高清| 在线播放国产精品| 91日韩在线视频| 亚洲在线免费视频| 精品日韩视频在线观看| 亚洲免费视频在线观看| 国内精品国产三级国产在线专| 亚洲韩国青草视频| 中文精品99久久国产香蕉| 日本久久中文字幕| 国产成人av网址| 国产日韩欧美中文在线播放| 日韩中文字幕不卡视频| 国产一区二区三区中文| 92福利视频午夜1000合集在线观看| 日韩在线视频观看| 欧美风情在线观看| 欧美日韩爱爱视频| 国产成人精品免高潮费视频| 国产精品视频男人的天堂| 最近2019年好看中文字幕视频| 国产精品入口夜色视频大尺度| 色悠久久久久综合先锋影音下载| 欧美一性一乱一交一视频| 亚洲精品按摩视频| 久热爱精品视频线路一| 国产精品免费在线免费| 国产亚洲aⅴaaaaaa毛片| 久久久亚洲福利精品午夜|