<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題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關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

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

        來源:懂視網 責編:小采 時間:2020-11-09 21:10:34
        文檔

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

        MySQL查詢優化:用子查詢代替非主鍵連接查詢實例介紹:一對多的兩張表,一般是一張表的外鍵關聯到另一個表的主鍵。但也有不一般的情況,也就是兩個表并非通過其中一個表的主鍵關聯。 例如: 代碼如下: create table t_team ( tid int primary key, tname varchar(100) ); create tabl
        推薦度:
        導讀MySQL查詢優化:用子查詢代替非主鍵連接查詢實例介紹:一對多的兩張表,一般是一張表的外鍵關聯到另一個表的主鍵。但也有不一般的情況,也就是兩個表并非通過其中一個表的主鍵關聯。 例如: 代碼如下: create table t_team ( tid int primary key, tname varchar(100) ); create tabl

        一對多的兩張表,一般是一張表的外鍵關聯到另一個表的主鍵。但也有不一般的情況,也就是兩個表并非通過其中一個表的主鍵關聯。
        例如:
        代碼如下:
        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

        您可能感興趣的文章:

      1. MySQL中基本的多表連接查詢教程
      2. 詳解MySQL中的分組查詢與連接查詢語句
      3. mysql連接查詢(左連接,右連接,內連接)
      4. MySQL查詢優化:連接查詢排序淺談
      5. MySQL筆記之連接查詢詳解
      6. MySQL優化之使用連接(join)代替子查詢
      7. 經典mysql連接查詢例題
      8. MySQL中對表連接查詢的簡單優化教程
      9. mysql多表連接查詢實例講解
      10. mysql多個left join連接查詢用法分析
      11. MySQL連接查詢實例詳解
      12. Mysql自連接查詢實例詳解
      13. 聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

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

        MySQL查詢優化:用子查詢代替非主鍵連接查詢實例介紹:一對多的兩張表,一般是一張表的外鍵關聯到另一個表的主鍵。但也有不一般的情況,也就是兩個表并非通過其中一個表的主鍵關聯。 例如: 代碼如下: create table t_team ( tid int primary key, tname varchar(100) ); create tabl
        推薦度:
        標簽: 效率 主鍵 mysql
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 有色视频在线观看免费高清在线直播| 亚洲免费精彩视频在线观看| 国产亚洲国产bv网站在线| 国产三级在线免费观看| 免费看国产曰批40分钟| 激情小说亚洲色图| 免费观看的a级毛片的网站| 亚洲AV永久无码精品一福利 | 久久99亚洲网美利坚合众国| 嫩草成人永久免费观看| 先锋影音资源片午夜在线观看视频免费播放| heyzo亚洲精品日韩| 一区二区三区免费视频播放器 | 国产在线观看免费视频播放器 | 国产成人亚洲精品蜜芽影院| 国产成人免费手机在线观看视频| 亚洲成a∧人片在线观看无码| 四虎影视永久免费视频观看| 人人爽人人爽人人片av免费| 国产成人精品日本亚洲专区61| 少妇性饥渴无码A区免费 | 亚洲女同成av人片在线观看| 久久九九全国免费| 最新仑乱免费视频| 亚洲色大18成人网站WWW在线播放| a视频免费在线观看| 亚洲视频免费在线观看| 成年丰满熟妇午夜免费视频| 羞羞视频免费观看| 亚洲精品福利视频| 最近最新中文字幕完整版免费高清| 亚洲av无码专区在线电影| 国产亚洲人成A在线V网站 | 毛片免费在线视频| 一级毛片完整版免费播放一区| 亚洲Av永久无码精品三区在线 | 亚洲AV中文无码乱人伦| 久久久久国产精品免费免费不卡| 亚洲乱码一二三四五六区| 免费v片在线观看| 久久青草91免费观看|