MySQL查詢最佳化:用子查詢代替非主鍵串連查詢執行個體介紹

來源:互聯網
上載者:User

一對多的兩張表,一般是一張表的外部索引鍵關聯到另一個表的主鍵。但也有不一般的情況,也就是兩個表並非通過其中一個表的主鍵關聯。
例如: 複製代碼 代碼如下:create table t_team
(
tid int primary key,
tname varchar(100)
);
create table t_people
(
pid int primary key,
pname varchar(100),
team_name varchar(100)
);

team表和people表是一對多的關係,team的tname是唯一的,people的pname也是唯一的,people表中外鍵team_name和team表的tname關聯,並不是和主鍵id關聯。
(PS:先不說這樣的設計合不合理,但如果真的攤上這事兒…..很多表的設計是每個表有一個id和uuid,id作為主鍵,uuid作關聯,和上面情況類似)
現在要查詢pname是"xxg"的people和team資訊:
SELECT * FROM t_team t,t_people p WHERE t.tname=p.team_name AND p.pname='xxg' LIMIT 1;

SELECT * FROM t_team t INNER JOIN t_people p ON t.tname=p.team_name WHERE p.pname='xxg' LIMIT 1;
執行一下,可以查詢出結果,但是如果資料量大的情況下,效率很低,執行很慢。
對於這種串連查詢,用子查詢來代替,查詢結果相同,但會效率更高:
SELECT * FROM (SELECT * FROM t_people WHERE pname='xxg' LIMIT 1) p, t_team t WHERE t.tname=p.team_name LIMIT 1;
子查詢中過濾了大量的資料(僅保留一條),再將結果來串連查詢,效率會大大提高。
(PS:另外,使用LIMIT 1也可以提高查詢效率,詳細:http://blog.csdn.net/xiao__gui/article/details/8726272 )
本人通過3條SQL測試兩種查詢方式的效率:
準備1萬條team資料,準備100萬條people資料。
造資料的預存程序: 複製代碼 代碼如下:BEGIN
DECLARE i INT;
START TRANSACTION;
SET i=0;
WHILE i<10000 DO
INSERT INTO t_team VALUES(i+1,CONCAT('team',i+1));
SET i=i+1;
END WHILE;
SET i=0;
WHILE i<1000000 DO
INSERT INTO t_people VALUES(i+1,CONCAT('people',i+1),CONCAT('team',i%10000+1));
SET i=i+1;
END WHILE;
COMMIT;
END

SQL語句執行效率:
串連查詢 複製代碼 代碼如下:SELECT * FROM t_team t,t_people p WHERE t.tname=p.team_nameAND p.pname='people20000' LIMIT 1;

Time:12.594 s
串連查詢 複製代碼 代碼如下:SELECT * FROM t_team t INNER JOIN t_peoplep ON t.tname=p.team_name WHERE p.pname='people20000' LIMIT 1;

Time:12.360 s
子查詢 複製代碼 代碼如下:SELECT * FROM (SELECT * FROM t_people WHEREpname='people20000' LIMIT 1) p, t_team t WHERE t.tname=p.team_name LIMIT 1;

Time:0.016 s

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.