久久机这里只有精品,国产69精品一区二区亚洲孕妇,91精品国产综合久久婷婷香蕉,午夜久久久久久电影

最新活動:電腦PC端+手機端+微網站+自適應網頁多模板選擇-建站388元起價!!!
當前位置:主頁 > SEO優化 > MySQL查詢優化:用子查詢代替非主鍵連接查詢實例

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

時間:2023-05-24 07:05:24 閱讀: 文章分類: SEO優化 作者: 網站技術員

導讀:2SEO優化一對多的兩張表,一般是一張表的外鍵關聯到另一個表的主鍵。但也有不一般的情況,也就是兩個表并非通過其中一個表的主鍵關聯。 例如: 復制代碼 代碼如下: creat網seo優化趨勢個業網站建設公司。

網seo優化趨勢個業網站建設公司一對多的兩張表,一般是一張表的外鍵關聯到另一個表的主鍵。但也有不一般的情況,也就是兩個表并非通過其中一個表的主鍵關聯。  例如:  復制代碼 代碼如下:     create table t_team  (  tid int primary key,  tname varchar(100)  );  create table t_people  (  pid int primary key,  pname varchar(100),  team_name va網站seo優化培訓rchar(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也可以提高查詢效率,詳細: )  本人通過3條SQL測試兩種查詢方式的效率:  準備1萬條team數據,準備100萬條people數據。  造數據的存儲過程: 百度seo網站優化; 復制代碼 代碼如下:     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_peopl個業網站建設公司e 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相關網seo優化趨勢個業網站建設公司。

關鍵詞標簽: 實例 SQL 主鍵

聲明: 本文由我的SEOUC技術文章主頁發布于:2023-05-24 ,文章MySQL查詢優化:用子查詢代替非主鍵連接查詢實例主要講述主鍵,實例,SQL網站建設源碼以及服務器配置搭建相關技術文章。轉載請保留鏈接: http://www.bifwcx.com/article/seo_6279.html

我的IDC 網站建設技術SEOUC.COM
專注網站建設,SEO優化,小程序設計制作搭建開發定制網站等,數千家網站定制開發案例,網站推廣技術服務。
  • 5000+合作客服
  • 8年從業經驗
  • 150+覆蓋行業
  • 最新熱門源碼技術文章

    主站蜘蛛池模板: 娱乐| 新乡市| 班玛县| 静宁县| 吉安市| 新乡县| 德清县| 临西县| 天峨县| 潜江市| 灵璧县| 和田市| 永顺县| 青阳县| 宜君县| 无棣县| 洛浦县| 芮城县| 东宁县| 洪雅县| 吉林市| 崇左市| 会理县| 合山市| 沙坪坝区| 石景山区| 永新县| 奈曼旗| 沽源县| 河西区| 波密县| 通山县| 丰顺县| 内乡县| 韶关市| 敖汉旗| 梁平县| 宁夏| 梁山县| 贵南县| 马鞍山市|