一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Mysql - MySQL查詢優化:用子查詢代替非主鍵連接查詢實例介紹

MySQL查詢優化:用子查詢代替非主鍵連接查詢實例介紹

2019-12-21 16:42MYSQL教程網 Mysql

對多的兩張表,一般是一張表的外鍵關聯到另一個表的主鍵,接下來為大家介紹下用子查詢代替非主鍵連接查詢,感興趣的朋友可以參考下哈,希望對你有所幫助

一對多的兩張表,一般是一張表的外鍵關聯到另一個表的主鍵。但也有不一般的情況,也就是兩個表并非通過其中一個表的主鍵關聯。 
例如: 

復制代碼代碼如下:


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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产精品视频免费观看 | 色哟哟观看 | 日本啊v在线观看 | 欧美侏儒xxx| 五月天导航 | 精品无人区麻豆乱码1区2 | 欧美a级在线观看 | avtt天堂网手机版亚洲 | 青青热久麻豆精品视频在线观看 | 91麻豆精品 | 国产在线观看色 | 4hc44四虎www在线影院男同 | 精品国产日韩亚洲一区在线 | 久久久无码精品亚洲A片软件 | 免费一级毛片在线播放 | 久久视频在线视频观看天天看视频 | 午夜dj免费视频观看社区 | 免费观看大片毛片 | 亚洲国产黄色 | 贰佰麻豆剧果冻传媒一二三区 | 美女福利视频网站 | 袖珍人与大黑人性视频 | 色老板在线免费观看 | 包臀裙女教师波多野结衣 | 韩剧消失的眼角膜免费完整版 | a级片在线观看免费 | 国产精品毛片无码 | 91国语精品自产拍在线观看一 | 无码AV熟妇素人内射V在线 | 四虎国产欧美成人影院 | 欧美大美bbb和大白屁股 | 青草视频免费观看在线观看 | 52zfl宅福利yxpjw | 国产精品露脸国语对白手机视频 | 国产精品原创巨作无遮挡 | 免费高清视频在线观看 | 国产精品99在线观看 | 天美影视文化传媒mv免费 | 小向美奈子av | 亚洲妇熟xxxxx妇色黄 | 好 舒服 好 粗 好硬免费视频 |