欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL查詢優(yōu)化:用子查詢代替非主鍵連接查詢實(shí)例介紹

 更新時(shí)間:2013年04月19日 15:08:51   作者:  
對(duì)多的兩張表,一般是一張表的外鍵關(guān)聯(lián)到另一個(gè)表的主鍵,接下來為大家介紹下用子查詢代替非主鍵連接查詢,感興趣的朋友可以參考下哈,希望對(duì)你有所幫助
一對(duì)多的兩張表,一般是一張表的外鍵關(guān)聯(lián)到另一個(gè)表的主鍵。但也有不一般的情況,也就是兩個(gè)表并非通過其中一個(gè)表的主鍵關(guān)聯(lián)。
例如:
復(fù)制代碼 代碼如下:

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測試兩種查詢方式的效率:
準(zhǔn)備1萬條team數(shù)據(jù),準(zhǔn)備100萬條people數(shù)據(jù)。
造數(shù)據(jù)的存儲(chǔ)過程:
復(fù)制代碼 代碼如下:

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ù)制代碼 代碼如下:

SELECT * FROM t_team t,t_people p WHERE t.tname=p.team_nameAND p.pname='people20000' LIMIT 1;

Time:12.594 s
連接查詢
復(fù)制代碼 代碼如下:

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ù)制代碼 代碼如下:

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

相關(guān)文章

  • 詳解MYSQL的備份還原(PHP實(shí)現(xiàn))

    詳解MYSQL的備份還原(PHP實(shí)現(xiàn))

    本篇文章是對(duì)MYSQL的備份還原進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • MySQL慢sql優(yōu)化思路詳細(xì)講解

    MySQL慢sql優(yōu)化思路詳細(xì)講解

    在日常開發(fā)工作中數(shù)據(jù)庫是常用的數(shù)據(jù)存儲(chǔ)組件,一旦使用了數(shù)據(jù)庫,那慢查詢SQL的優(yōu)化是繞不開的一道坎,下面這篇文章主要給大家介紹了關(guān)于MySQL慢sql優(yōu)化思路的相關(guān)資料,需要的朋友可以參考下
    2023-01-01
  • MySQL自定義函數(shù)和存儲(chǔ)過程示例詳解

    MySQL自定義函數(shù)和存儲(chǔ)過程示例詳解

    這篇文章主要給大家介紹了關(guān)于MySQL自定義函數(shù)和存儲(chǔ)過程的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • 淺談MySQL中的group by

    淺談MySQL中的group by

    這篇文章主要介紹了MySQL中的group by,MySQL的group by用于對(duì)查詢的數(shù)據(jù)進(jìn)行分組;此外MySQL提供having子句對(duì)分組內(nèi)的數(shù)據(jù)進(jìn)行過濾。下面來看看文章對(duì)此的具體介紹,需要的朋友可以參考一下,希望對(duì)你有所幫助
    2021-11-11
  • mysql事務(wù)select for update及數(shù)據(jù)的一致性處理講解

    mysql事務(wù)select for update及數(shù)據(jù)的一致性處理講解

    今天小編就為大家分享一篇關(guān)于mysql事務(wù)select for update及數(shù)據(jù)的一致性處理講解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • mysql中Update未加索引導(dǎo)致的微服務(wù)模塊不可用

    mysql中Update未加索引導(dǎo)致的微服務(wù)模塊不可用

    本文主要介紹了mysql中Update未加索引導(dǎo)致的微服務(wù)模塊不可用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • mysql5.6安裝配置方法圖文教程

    mysql5.6安裝配置方法圖文教程

    這篇文章主要為大家分享了mysql5.6安裝配置方法圖文教程,感興趣的朋友可以參考一下
    2016-06-06
  • MySQL查詢優(yōu)化:連接查詢排序limit(join、order by、limit語句)介紹

    MySQL查詢優(yōu)化:連接查詢排序limit(join、order by、limit語句)介紹

    兩張表連接查詢并limit,SQL效率很高,但是加上order by以后,語句的執(zhí)行時(shí)間變的巨長,效率巨低,接下來為大家介紹下連接查詢排序limit
    2013-04-04
  • 快速學(xué)習(xí)MySQL基礎(chǔ)知識(shí)

    快速學(xué)習(xí)MySQL基礎(chǔ)知識(shí)

    這篇文章主要介紹了MySQL基礎(chǔ)知識(shí)的相關(guān)資料,文中講解非常細(xì)致,幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • mysql中Load Data記錄換行問題的解決方法

    mysql中Load Data記錄換行問題的解決方法

    有關(guān)mysql中Load Data記錄換行的問題的解決方法, 需要的朋友可以參考下
    2013-02-02

最新評(píng)論