<source id="r5i4f"></source>
<source id="r5i4f"><menu id="r5i4f"><delect id="r5i4f"></delect></menu></source>
<source id="r5i4f"><menuitem id="r5i4f"></menuitem></source><source id="r5i4f"></source>
<source id="r5i4f"><menu id="r5i4f"></menu></source>
<video id="r5i4f"></video>
<source id="r5i4f"></source>

位置: 編程技術 - 正文

MySQL的LEFT JOIN表連接的進階學習教程

發布時間:2024-01-29

推薦整理分享MySQL的LEFT JOIN表連接的進階學習教程,希望有所幫助,僅作參考,歡迎閱讀內容。

文章相關熱門搜索詞:,內容如對您有幫助,希望把文章鏈接給更多的朋友!

LEFT JOIN的主表

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

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

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

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

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

MySQL的LEFT JOIN表連接的進階學習教程

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

LEFT JOIN查詢效率分析user表:

sql:

分析:注意到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的。如:

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

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

MySQL中對表連接查詢的簡單優化教程 在MySQL中,ALEFTJOINBjoin_condition執行過程如下:·根據表A和A依賴的所有表設置表B?!じ鶕﨤EFTJOIN條件中使用的所有表(除了B)設置表A?!EFTJOIN條件用于確定

解決Java程序使用MySQL時返回參數為亂碼的示例教程 先說MySQL的字符集問題。Windows下可通過修改my.ini內的default-character-set=utf8//客戶端的默認字符集在MySQL客戶端工具中輸入SHOWVARIABLESLIKE'character%';顯示如下

MySQL中觸發器的基礎學習教程 0.觸發器的基本概念觸發器是一種特殊的存儲過程,它在插入,刪除或修改特定表中的數據時觸發執行,它比數據庫本身標準的功能有更精細和更復雜的

標簽: MySQL的LEFT JOIN表連接的進階學習教程

本文鏈接地址:http://www.lzbosye.cn/biancheng/312407.html 轉載請保留說明!

上一篇:將MySQL查詢結果按值排序的簡要教程(mysql將查詢結果存到另一個表)

下一篇:MySQL中對表連接查詢的簡單優化教程(mysql 連接語句)

  • 匯算清繳時納稅調整表調增金額是怎么算出來的
  • 小微企業的認定標準2023年
  • 培訓學??梢圆豢梢杂萌細馊∨癄t
  • 個稅系統經營所得如何添加人員信息
  • 企業所得稅中的所得
  • 上市審計費入賬
  • 簡易征收類型
  • 不征稅收入的所得稅處理
  • 公司試駕車購置稅怎么交
  • 失業養老保險如何辦理
  • 借款合同的印花稅稅率
  • 股權轉讓所得應納稅所得額
  • 小規模納稅人專票開1%還是3%
  • 印花稅必須每個月零申報嗎
  • 個體戶需要交稅嗎要交多少
  • 外管證稅收預繳稅率是多少?
  • 年報填寫中,認繳出資時間怎么填?
  • 企業銀行密碼器
  • 注冊資本印花稅按實繳還是認繳
  • 土地出讓金產生的利息交契稅嗎
  • 企業代收代支的非稅收入需要繳稅嗎?
  • 研發費用資本化可以加計扣除嗎
  • 個體工商戶怎么交社保
  • 政府投資農業項目
  • 企業奠基費用如何入賬
  • 股東投入的資金可以退回嗎
  • 開具紅字發票后所沖銷的銷項稅應怎么處理?
  • php 回調函數
  • php字符串操作函數
  • 如何使用微信公交付款
  • 豹七三七粉的價格
  • PHP:is_dir()的用法_Filesystem函數
  • 草叢里的野花像
  • 固定資產管理系統多少錢
  • kindeditor編輯器圖片上傳
  • 企業重組特殊性稅務處理計稅基礎
  • 所得稅分配表分錄怎么寫
  • vue學起來困難嗎
  • 未記賬憑證怎么變成已記賬憑證
  • 殘保金計稅基數是什么
  • 行政事業單位資產管理辦法
  • mysql用在哪些方面
  • 主營業務稅金及附加和稅金及附加的區別
  • 哪些普通發票可以抵扣
  • 企業所得稅申報錯誤怎么更改
  • 跨地區經營增值稅如何繳納
  • 印花稅憑證名稱如何選擇
  • 交易性金融資產的入賬價值
  • 公司法人往公司賬戶打錢怎么能換回來
  • 壞賬準備的會計處理方法
  • 企業虧損為什么還繼續
  • 公司提供給員工暫借款未還款離職
  • 發票章摔壞了一個角,還能蓋嗎
  • 怎樣編制銀行存款憑證
  • ubuntu docker教程
  • mysqld關閉
  • win8系統怎么查看隱藏文件
  • unix系統命令大全
  • win10系統共享打印機無法訪問怎么解決
  • xp桌面字體有陰影怎么去掉
  • 怎么修改win10登錄名
  • win102020h2
  • w8系統怎么連接投影儀
  • windows7開機后顯示配置失敗
  • windows7老是死機
  • 安卓獲取設備信息
  • Error: String types not allowed (at 'layout_gravity' with value 'bottom/center_horizontal').
  • 全部刪除文件快捷鍵
  • 置頂聊天折疊怎么開啟
  • 利用職務之便謀取私利是什么罪
  • android的edittext在哪
  • python,for循環
  • js的異步解決方案有哪些
  • Python 正則表達式的高級用法
  • javascript下拉列表怎么做
  • js字段截取
  • 電子發票如何蓋電子章
  • 安徽國家稅務局增值稅發票查詢平臺
  • 地方稅務局工作內容
  • 濟南車輛購置稅完稅證明電子版
  • 免責聲明:網站部分圖片文字素材來源于網絡,如有侵權,請及時告知,我們會第一時間刪除,謝謝! 郵箱:opceo@qq.com

    鄂ICP備2023003026號

    国产一级一片内射视频插放,中字幕视频在线永久在线观看免费,97超碰免费,精品国产午夜激无码毛片
    <source id="r5i4f"></source>
    <source id="r5i4f"><menu id="r5i4f"><delect id="r5i4f"></delect></menu></source>
    <source id="r5i4f"><menuitem id="r5i4f"></menuitem></source><source id="r5i4f"></source>
    <source id="r5i4f"><menu id="r5i4f"></menu></source>
    <video id="r5i4f"></video>
    <source id="r5i4f"></source>