<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
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        MySQL的LEFTJOIN表連接的進階學習教程_MySQL

        來源:懂視網 責編:小采 時間:2020-11-09 20:16:16
        文檔

        MySQL的LEFTJOIN表連接的進階學習教程_MySQL

        MySQL的LEFTJOIN表連接的進階學習教程_MySQL:LEFT JOIN的主表這里所說的主表是指在連接查詢里MySQL以哪個表為主進行查詢。比如說在LEFT JOIN查詢里,一般來說左表就是主表,但這只是經驗之談,很多時候經驗主義是靠不住的,為了說明問題,先來個例子,建兩個演示用的表categories和posts:CR
        推薦度:
        導讀MySQL的LEFTJOIN表連接的進階學習教程_MySQL:LEFT JOIN的主表這里所說的主表是指在連接查詢里MySQL以哪個表為主進行查詢。比如說在LEFT JOIN查詢里,一般來說左表就是主表,但這只是經驗之談,很多時候經驗主義是靠不住的,為了說明問題,先來個例子,建兩個演示用的表categories和posts:CR

        LEFT JOIN的主表

        這里所說的主表是指在連接查詢里MySQL以哪個表為主進行查詢。比如說在LEFT JOIN查詢里,一般來說左表就是主表,但這只是經驗之談,很多時候經驗主義是靠不住的,為了說明問題,先來個例子,建兩個演示用的表categories和posts:

        CREATE TABLE IF NOT EXISTS `categories` (
        `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
        `name` varchar(15) NOT NULL,
        `created` datetime NOT NULL,
        PRIMARY KEY (`id`)
        );
        
        CREATE TABLE IF NOT EXISTS `posts` (
        `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
        `category_id` int(10) unsigned NOT NULL,
        `title` varchar(100) NOT NULL,
        `content` varchar(200) NOT NULL,
        `created` datetime NOT NULL,
        PRIMARY KEY (`id`),
        KEY `category_id` (`category_id`)
        );

        先注意一下每個表的索引情況,以后會用到,記得隨便插入一點測試數據,不用太多,但怎么也得兩行以上,然后執行以下SQL:

        EXPLAIN SELECT *
        FROM posts
        LEFT JOIN categories ON posts.category_id = categories.id
        WHERE categories.id = ‘一個已經存在的ID'
        ORDER BY posts.created DESC
        table key Extra
        categories PRIMARY Using filesort
        posts category_id Using where

        在explain的結果中,第一行表示的表就是主表,所以說在此查詢里categories是主表,而在我們的經驗里,LEFT JOIN查詢里,左表(posts表)才應該是主表,這產生一個根本的矛盾,MySQL之所以這樣處理,是因為在我們的WHERE部分,查詢條件是按照categories表的字段來進行篩選的,而恰恰categories表存在合適的索引,所以在查詢時把categories表作為主表更有利于縮小結果集。

        那explain結果中的Using filesort又是為什么呢?這是因為主表是categories表,從表是posts表,而我們使用從表的字段去ORDER BY,這通常不是一個好選擇,最好改成主表字段,如果鑒于需求所限,無法改成主表的字段,那么可以嘗試添加如下索引:

        ALTER TABLE `posts` ADD INDEX ( `category_id` , `created` );

        再運行SQL時就不會有Using filesort了,這是因為主表categories在通過category_id連接從表posts時,可以進而通過索引直接得到排序后的posts結果。

        主觀上一旦搞錯了主表,可能怎么調整索引都得不到高效的SQL,所以在寫SQL時,比如說在寫LEFT JOIN查詢時,如果希望左表是主表,那么就要保證在WHERE語句里的查詢條件盡可能多的使用左表字段,進而,一旦確定了主表,也最好只通過主表字段去ORDER BY。

        LEFT JOIN查詢效率分析
        user表:

        id | name
        ---------
        1 | libk
        2 | zyfon
        3 | daodao
        
        user_action表:
        
        user_id | action
        ---------------
        1 | jump
        1 | kick
        1 | jump
        2 | run
        4 | swim

        sql:

        select id, name, action from user as u
        left join user_action a on u.id = a.user_id
        
        result:
        id | name | action
        --------------------------------
        1 | libk | jump ①
        1 | libk | kick ②
        1 | libk | jump ③
        2 | zyfon | run ④
        3 | daodao | null ⑤

        分析:
        注意到user_action中還有一個user_id=4, action=swim的紀錄,但是沒有在結果中出現,
        而user表中的id=3, name=daodao的用戶在user_action中沒有相應的紀錄,但是卻出現在了結果集中
        因為現在是left join,所有的工作以left為準.
        結果1,2,3,4都是既在左表又在右表的紀錄,5是只在左表,不在右表的紀錄


        結論:
        我們可以想象left join 是這樣工作的
        從左表讀出一條,選出所有與on匹配的右表紀錄(n條)進行連接,形成n條紀錄(包括重復的行,如:結果1和結果3),
        如果右邊沒有與on條件匹配的表,那連接的字段都是null.
        然后繼續讀下一條。

        引申:
        我們可以用右表沒有on匹配則顯示null的規律, 來找出所有在左表,不在右表的紀錄, 注意用來判斷的那列必須聲明為not null的。
        如:

        select id, name, action from user as u
        left join user_action a on u.id = a.user_id
        where a.user_id is NULL

        (注意:1.列值為null應該用is null 而不能用=NULL
        2.這里a.user_id 列必須聲明為 NOT NULL 的)

        result:
        id | name | action
        --------------------------
        3 | daodao | NULL
        
        --------------------------------------------------------------------------------

        Tips:
        1. on a.c1 = b.c1 等同于 using(c1)
        2. INNER JOIN 和 , (逗號) 在語義上是等同的
        3. 當 MySQL 在從一個表中檢索信息時,你可以提示它選擇了哪一個索引。
        如果 EXPLAIN 顯示 MySQL 使用了可能的索引列表中錯誤的索引,這個特性將是很有用的。
        通過指定 USE INDEX (key_list),你可以告訴 MySQL 使用可能的索引中最合適的一個索引在表中查找記錄行。
        可選的二選一句法 IGNORE INDEX (key_list) 可被用于告訴 MySQL 不使用特定的索引。
        4. 一些例子:

        mysql> SELECT * FROM table1,table2 WHERE table1.id=table2.id;
        mysql> SELECT * FROM table1 LEFT JOIN table2 ON table1.id=table2.id;
        mysql> SELECT * FROM table1 LEFT JOIN table2 USING (id);
        mysql> SELECT * FROM table1 LEFT JOIN table2 ON table1.id=table2.id
        -> LEFT JOIN table3 ON table2.id=table3.id;
        mysql> SELECT * FROM table1 USE INDEX (key1,key2)
        -> WHERE key1=1 AND key2=2 AND key3=3;
        mysql> SELECT * FROM table1 IGNORE INDEX (key3)
        -> WHERE key1=1 AND key2=2 AND key3=3;

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        MySQL的LEFTJOIN表連接的進階學習教程_MySQL

        MySQL的LEFTJOIN表連接的進階學習教程_MySQL:LEFT JOIN的主表這里所說的主表是指在連接查詢里MySQL以哪個表為主進行查詢。比如說在LEFT JOIN查詢里,一般來說左表就是主表,但這只是經驗之談,很多時候經驗主義是靠不住的,為了說明問題,先來個例子,建兩個演示用的表categories和posts:CR
        推薦度:
        標簽: 連接 教程 mysql
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top 主站蜘蛛池模板: 亚洲精品无码久久久久去q| 亚洲中文无码永久免费| 亚洲国产成人爱av在线播放| 亚洲精品无码永久在线观看男男 | 国产亚洲福利一区二区免费看 | 亚洲福利中文字幕在线网址| 美女羞羞视频免费网站| 成人免费视频小说| 国产成人亚洲精品狼色在线| 亚洲中文字幕在线无码一区二区| 久久亚洲AV成人无码国产最大| 成人午夜免费福利| 日韩色视频一区二区三区亚洲| 永久免费视频网站在线观看| 亚洲国产精品白丝在线观看| 你好老叔电影观看免费| 亚洲精品无码专区久久久| 久久青青草原国产精品免费| 国产乱子伦精品免费无码专区| 国产偷国产偷亚洲高清人 | 亚洲精品无码不卡| 国产综合激情在线亚洲第一页| 免费大黄网站在线看| 丝瓜app免费下载网址进入ios| 破了亲妺妺的处免费视频国产| 亚洲第一se情网站| 亚洲国产精品无码成人片久久| 久久亚洲精品成人无码| 国产成人综合亚洲AV第一页| 亚洲免费闲人蜜桃| 亚洲嫩模在线观看| 毛片免费全部播放一级| 搜日本一区二区三区免费高清视频 | 黄色网址免费观看| 4444亚洲国产成人精品| 成人人免费夜夜视频观看| 72pao国产成视频永久免费| 亚洲成A人片在线观看无码3D| 久久99毛片免费观看不卡| 亚洲人成无码网站在线观看| 中文字幕亚洲电影|