国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專(zhuān)題視頻專(zhuān)題問(wèn)答1問(wèn)答10問(wèn)答100問(wèn)答1000問(wèn)答2000關(guān)鍵字專(zhuān)題1關(guān)鍵字專(zhuān)題50關(guān)鍵字專(zhuān)題500關(guān)鍵字專(zhuān)題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專(zhuān)題關(guān)鍵字專(zhuān)題tag2tag3文章專(zhuān)題文章專(zhuān)題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專(zhuān)題3
問(wèn)答文章1 問(wèn)答文章501 問(wèn)答文章1001 問(wèn)答文章1501 問(wèn)答文章2001 問(wèn)答文章2501 問(wèn)答文章3001 問(wèn)答文章3501 問(wèn)答文章4001 問(wèn)答文章4501 問(wèn)答文章5001 問(wèn)答文章5501 問(wèn)答文章6001 問(wèn)答文章6501 問(wèn)答文章7001 問(wèn)答文章7501 問(wèn)答文章8001 問(wèn)答文章8501 問(wèn)答文章9001 問(wèn)答文章9501
當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

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

來(lái)源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-09 21:10:34
文檔

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

MySQL查詢(xún)優(yōu)化:用子查詢(xún)代替非主鍵連接查詢(xún)實(shí)例介紹:一對(duì)多的兩張表,一般是一張表的外鍵關(guān)聯(lián)到另一個(gè)表的主鍵。但也有不一般的情況,也就是兩個(gè)表并非通過(guò)其中一個(gè)表的主鍵關(guān)聯(lián)。 例如: 代碼如下: create table t_team ( tid int primary key, tname varchar(100) ); create tabl
推薦度:
導(dǎo)讀MySQL查詢(xún)優(yōu)化:用子查詢(xún)代替非主鍵連接查詢(xún)實(shí)例介紹:一對(duì)多的兩張表,一般是一張表的外鍵關(guān)聯(lián)到另一個(gè)表的主鍵。但也有不一般的情況,也就是兩個(gè)表并非通過(guò)其中一個(gè)表的主鍵關(guān)聯(lián)。 例如: 代碼如下: create table t_team ( tid int primary key, tname varchar(100) ); create tabl

一對(duì)多的兩張表,一般是一張表的外鍵關(guān)聯(lián)到另一個(gè)表的主鍵。但也有不一般的情況,也就是兩個(gè)表并非通過(guò)其中一個(gè)表的主鍵關(guān)聯(lián)。
例如:
代碼如下:
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:先不說(shuō)這樣的設(shè)計(jì)合不合理,但如果真的攤上這事兒…..很多表的設(shè)計(jì)是每個(gè)表有一個(gè)id和uuid,id作為主鍵,uuid作關(guān)聯(lián),和上面情況類(lèi)似)
現(xiàn)在要查詢(xú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í)行一下,可以查詢(xún)出結(jié)果,但是如果數(shù)據(jù)量大的情況下,效率很低,執(zhí)行很慢。
對(duì)于這種連接查詢(xún),用子查詢(xún)來(lái)代替,查詢(xún)結(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;
子查詢(xún)中過(guò)濾了大量的數(shù)據(jù)(僅保留一條),再將結(jié)果來(lái)連接查詢(xún),效率會(huì)大大提高。
(PS:另外,使用LIMIT 1也可以提高查詢(xún)效率,詳細(xì):http://blog.csdn.net/xiao__gui/article/details/8726272 )
本人通過(guò)3條SQL測(cè)試兩種查詢(xún)方式的效率:
準(zhǔn)備1萬(wàn)條team數(shù)據(jù),準(zhǔn)備100萬(wàn)條people數(shù)據(jù)。
造數(shù)據(jù)的存儲(chǔ)過(guò)程:
代碼如下:
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語(yǔ)句執(zhí)行效率:
連接查詢(xún)
代碼如下:
SELECT * FROM t_team t,t_people p WHERE t.tname=p.team_nameAND p.pname='people20000' LIMIT 1;

Time:12.594 s
連接查詢(xún)
代碼如下:
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
子查詢(xún)
代碼如下:
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中基本的多表連接查詢(xún)教程
  • 詳解MySQL中的分組查詢(xún)與連接查詢(xún)語(yǔ)句
  • mysql連接查詢(xún)(左連接,右連接,內(nèi)連接)
  • MySQL查詢(xún)優(yōu)化:連接查詢(xún)排序淺談
  • MySQL筆記之連接查詢(xún)?cè)斀?/li>
  • MySQL優(yōu)化之使用連接(join)代替子查詢(xún)
  • 經(jīng)典mysql連接查詢(xún)例題
  • MySQL中對(duì)表連接查詢(xún)的簡(jiǎn)單優(yōu)化教程
  • mysql多表連接查詢(xún)實(shí)例講解
  • mysql多個(gè)left join連接查詢(xún)用法分析
  • MySQL連接查詢(xún)實(shí)例詳解
  • Mysql自連接查詢(xún)實(shí)例詳解
  • 聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

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

    MySQL查詢(xún)優(yōu)化:用子查詢(xún)代替非主鍵連接查詢(xún)實(shí)例介紹:一對(duì)多的兩張表,一般是一張表的外鍵關(guān)聯(lián)到另一個(gè)表的主鍵。但也有不一般的情況,也就是兩個(gè)表并非通過(guò)其中一個(gè)表的主鍵關(guān)聯(lián)。 例如: 代碼如下: create table t_team ( tid int primary key, tname varchar(100) ); create tabl
    推薦度:
    標(biāo)簽: 效率 主鍵 mysql
    • 熱門(mén)焦點(diǎn)

    最新推薦

    猜你喜歡

    熱門(mén)推薦

    專(zhuān)題
    Top
    主站蜘蛛池模板: 亚洲 欧美综合小说区图片区 | 中文国产成人精品少久久 | 最新国产精品电影入口 | 国产第一页在线视频 | 亚洲韩精品欧美一区二区三区 | www国产精品 | 日韩亚洲欧美一区噜噜噜 | 久久国语精品 | 亚洲欧美日韩第一页 | 国产精品成人一区二区1 | 全免费毛片在线播放 | 久久精品男人影院 | 亚洲区中文字幕 | 日本亚洲国产精品久久 | 一区二区三区美女 | 国产精品免费视频播放 | 亚洲欧美中文字幕 | 在线播放国产一区二区三区 | 国产片一区二区三区 | 热久久国产欧美一区二区精品 | 国产免费三a在线 | 亚洲国产成人久久一区久久 | 欧美日韩在线高清 | 免费a黄色 | 性久久久久| 亚洲欧美日韩在线观看 | 日韩精品一区二区三区视频 | 欧美一区二区三区视频 | 免费一级 | 久久久久久国产精品免费 | 亚洲一区二区在线成人 | 久久亚洲国产成人影院 | 四虎影视永久在线 | 日本全黄视频 | 日韩欧美伊人久久大香线蕉 | 国产毛片一区二区三区精品 | 高h肉肉视频在线播放观看 福利视频一区二区三区 | 97久久精品一区二区三区 | 视频一区久久 | 国产免费网 | 欧美精品v日韩精品v国产精品 |