MySQL查詢優(yōu)化:用子查詢代替非主鍵連接查詢實(shí)例介紹_MySQL教程
推薦:MySQL查詢優(yōu)化:LIMIT 1避免全表掃描提高查詢效率在某些情況下,如果明知道查詢結(jié)果只有一個(gè),SQL語句中使用LIMIT 1會(huì)提高查詢效率,感興趣的朋友可以了解下哈,希望對(duì)你優(yōu)化mysql查詢有所幫助
一對(duì)多的兩張表,一般是一張表的外鍵關(guān)聯(lián)到另一個(gè)表的主鍵。但也有不一般的情況,也就是兩個(gè)表并非通過其中一個(gè)表的主鍵關(guān)聯(lián)。例如:
復(fù)制代碼 代碼如下:www.hl5o.cn
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表是一對(duì)多的關(guān)系,team的tname是唯一的,people的pname也是唯一的,people表中外鍵team_name和team表的tname關(guān)聯(lián),并不是和主鍵id關(guān)聯(lián)。
(PS:先不說這樣的設(shè)計(jì)合不合理,但如果真的攤上這事兒…..很多表的設(shè)計(jì)是每個(gè)表有一個(gè)id和uuid,id作為主鍵,uuid作關(guān)聯(lián),和上面情況類似)
現(xiàn)在要查詢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;
執(zhí)行一下,可以查詢出結(jié)果,但是如果數(shù)據(jù)量大的情況下,效率很低,執(zhí)行很慢。
對(duì)于這種連接查詢,用子查詢來代替,查詢結(jié)果相同,但會(huì)效率更高:
SELECT * FROM (SELECT * FROM t_people WHERE pname='xxg' LIMIT 1) p, t_team t WHERE t.tname=p.team_name LIMIT 1;
子查詢中過濾了大量的數(shù)據(jù)(僅保留一條),再將結(jié)果來連接查詢,效率會(huì)大大提高。
(PS:另外,使用LIMIT 1也可以提高查詢效率,詳細(xì):http://blog.csdn.net/xiao__gui/article/details/8726272 )
本人通過3條SQL測(cè)試兩種查詢方式的效率:
準(zhǔn)備1萬條team數(shù)據(jù),準(zhǔn)備100萬條people數(shù)據(jù)。
造數(shù)據(jù)的存儲(chǔ)過程:
復(fù)制代碼 代碼如下:www.hl5o.cn
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語句執(zhí)行效率:
連接查詢
復(fù)制代碼 代碼如下:www.hl5o.cn
SELECT * FROM t_team t,t_people p WHERE t.tname=p.team_nameAND p.pname='people20000' LIMIT 1;
Time:12.594 s
連接查詢
復(fù)制代碼 代碼如下:www.hl5o.cn
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
子查詢
復(fù)制代碼 代碼如下:www.hl5o.cn
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
分享:Mysql高性能備份方案解決數(shù)據(jù)不間斷訪問備份特點(diǎn): 1、在大多數(shù)情況下,這種方式幾乎算得上是熱備。它無需關(guān)閉服務(wù),只需要設(shè)置只讀或者類似這樣的限制。 2、支持所有基于本地磁盤的存儲(chǔ)引擎,比如MYISAM、InnoDB和BDB,還支持Solid、PrimeXT和Faction。 3、備份速度最快,因?yàn)槟阒恍枰截愊嚓P(guān)的二進(jìn)制數(shù)據(jù)
相關(guān)MySQL教程:
- MSSQL清空日志刪除日志文件
- 關(guān)于數(shù)據(jù)庫中保留小數(shù)位的問題
- 解析mysql與Oracle update的區(qū)別
- mysql 導(dǎo)入導(dǎo)出數(shù)據(jù)庫以及函數(shù)、存儲(chǔ)過程的介紹
- MySQL——修改root密碼的4種方法(以windows為例)
- 解決MYSQL出現(xiàn)Can''t create/write to file ''#sql_5c0_0.MYD''的問題
- 深入理解SQL的四種連接-左外連接、右外連接、內(nèi)連接、全連接
- 解析:內(nèi)聯(lián),左外聯(lián),右外聯(lián),全連接,交叉連接的區(qū)別
- mysql出現(xiàn)“Incorrect key file for table”處理方法
- mysql重裝后出現(xiàn)亂碼設(shè)置為utf8可解決
- 淺析一個(gè)MYSQL語法(在查詢中使用count)的兼容性問題
- 解析MySQL中INSERT INTO SELECT的使用
MySQL教程Rss訂閱編程教程搜索
MySQL教程推薦
- mysql創(chuàng)建函數(shù)出現(xiàn)1418錯(cuò)誤的解決辦法
- 10大關(guān)系數(shù)據(jù)庫SQL注入工具一覽
- MySQL 關(guān)于表復(fù)制 insert into 語法的詳細(xì)介紹
- MySQL 5.6 如何更改安全的處理密碼探討
- Mysql DNS反向解析導(dǎo)致連接超時(shí)過程分析(skip-name-resolve)
- MySQL筆記之連接查詢?cè)斀?/a>
- MySQL數(shù)據(jù)庫備份和還原的常用命令
- mysql 超大數(shù)據(jù)/表管理技巧
- mysql使用source 命令亂碼問題解決方法
- KB967723補(bǔ)丁造成的MYSQL在Win2003上頻繁連接不上
猜你也喜歡看這些
- 解讀VB實(shí)現(xiàn)SQL Server 2000存儲(chǔ)過程調(diào)用
- sql server多行數(shù)據(jù)拼接的實(shí)例方法
- SQL Server 查詢分析器快捷鍵集合
- SQL server 表操作介紹
- 如何使用 SQL Server 數(shù)據(jù)庫嵌套子查詢
- mssql2005字符串連接方法 避免無效的連接錯(cuò)誤
- 通過JDBC連接DB2數(shù)據(jù)庫技巧
- 解讀數(shù)據(jù)庫的一些常識(shí)
- sqlserver中delete、update中使用表別名和oracle的區(qū)別
- 詳解轉(zhuǎn)換 SQL數(shù)據(jù)庫時(shí)的疑難問題
- 相關(guān)鏈接:
- 教程說明:
MySQL教程-MySQL查詢優(yōu)化:用子查詢代替非主鍵連接查詢實(shí)例介紹
。