日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

mysql 子查询 主键外键_MySQL查询优化:用子查询代替非主键连接查询实例介绍

發(fā)布時(shí)間:2025/4/5 数据库 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql 子查询 主键外键_MySQL查询优化:用子查询代替非主键连接查询实例介绍 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

一對(duì)多的兩張表,一般是一張表的外鍵關(guān)聯(lián)到另一個(gè)表的主鍵。但也有不一般的情況,也就是兩個(gè)表并非通過其中一個(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:先不說這樣的設(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萬(wàn)條team數(shù)據(jù),準(zhǔn)備100萬(wàn)條people數(shù)據(jù)。

造數(shù)據(jù)的存儲(chǔ)過程:

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),i%10000+1));

SET i=i+1;

END WHILE;

COMMIT;

END

sql語(yǔ)句執(zhí)行效率:

連接查詢

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

總結(jié)

如果覺得編程之家網(wǎng)站內(nèi)容還不錯(cuò),歡迎將編程之家網(wǎng)站推薦給程序員好友。

本圖文內(nèi)容來源于網(wǎng)友網(wǎng)絡(luò)收集整理提供,作為學(xué)習(xí)參考使用,版權(quán)屬于原作者。

如您喜歡交流學(xué)習(xí)經(jīng)驗(yàn),點(diǎn)擊鏈接加入交流1群:1065694478(已滿)交流2群:163560250

總結(jié)

以上是生活随笔為你收集整理的mysql 子查询 主键外键_MySQL查询优化:用子查询代替非主键连接查询实例介绍的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。