亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

mysql查詢語句join、on、where的執(zhí)行順序

 更新時(shí)間:2022年11月16日 10:50:23   作者:lihongbao80  
這篇文章主要介紹了mysql查詢語句join、on、where的執(zhí)行順序,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

MySQL 的執(zhí)行順序

一、典型SELECT語句完整的執(zhí)行順序

1)from子句組裝來自不同數(shù)據(jù)源的數(shù)據(jù);

2)使用on進(jìn)行join連接的數(shù)據(jù)篩選

3)where子句基于指定的條件對(duì)記錄行進(jìn)行篩選;

4)group by子句將數(shù)據(jù)劃分為多個(gè)分組;

5)cube, rollup

6)使用聚集函數(shù)進(jìn)行計(jì)算;

7)使用having子句篩選分組;

8)計(jì)算所有的表達(dá)式;

9)計(jì)算select的字段;

10)使用distinct 進(jìn)行數(shù)據(jù)去重

11)使用order by對(duì)結(jié)果集進(jìn)行排序。

12)選擇TOPN的數(shù)據(jù)

二、from

如果是采用的 關(guān)聯(lián) from tableA, tableB ,這2個(gè)表會(huì)先組織進(jìn)行笛卡爾積,然后在進(jìn)行下面的 where、group by 等操作。

三、on

如果使用left join, inner join 或者 outer full join的時(shí)候,使用on 進(jìn)行條件篩選后,在進(jìn)行join。

看下面的2個(gè)sql 和結(jié)果。2者的區(qū)別僅僅是在on后面的一個(gè)語句在on和where位置的不同。 由此可以看出是先通過on 進(jìn)行條件篩選,然后在join,最后在進(jìn)行where條件篩選。

  • 假如:是先進(jìn)行join,在進(jìn)行on的話,會(huì)產(chǎn)生一個(gè)笛卡爾積,然后在篩選。這樣的left join 和 直連接 沒有任何的區(qū)別。 所以肯定是先on 條件篩選后,在進(jìn)行join。
  • 假如:是在進(jìn)行where 后,在on,在進(jìn)行join, 下面2個(gè)sql的返回結(jié)果應(yīng)該是一樣的。由此可以見,where是針對(duì) join 后的集合進(jìn)行的篩選。

綜上: 先 執(zhí)行on 條件篩選, 在進(jìn)行join, 最后進(jìn)行where 篩選

SELECT DISTINCT a.domain , b.domain
FROM mal_nxdomains_raw a
LEFT JOIN mal_nxdomains_detail b ON a.domain = b.domain AND b.date = ‘20160403'
WHERE a.date = ‘20160403'

SELECT DISTINCT a.domain , b.domain
FROM mal_nxdomains_raw a
LEFT JOIN mal_nxdomains_detail b ON a.domain = b.domain #and b.date = ‘20160403'
WHERE a.date = ‘20160403'
AND b.date = ‘20160403'

四、on 條件與where 條件

1、使用位置

on 條件位置在join后面

where 條件在join 與on完成的后面

2、使用對(duì)象

on 的使用對(duì)象是被關(guān)聯(lián)表

where的使用對(duì)象可以是主表,也可以是關(guān)聯(lián)表

3、選擇與使用

主表?xiàng)l件篩選:只能在where后面使用。

被關(guān)聯(lián)表,如果是想縮小join范圍,可以放置到on后面。如果是關(guān)聯(lián)后再查詢,可以放置到where 后面。

如果left join 中,where條件有對(duì)被關(guān)聯(lián)表的 關(guān)聯(lián)字段的 非空查詢,與使用inner join的效果后,在進(jìn)行where 篩選的效果是一樣的。不能起到left join的作用。

五、join 流程

tableA join tableB, 從A表中拿出一條數(shù)據(jù),到B表中進(jìn)行掃描匹配。所以A的行數(shù)決定查詢次數(shù),B表的行數(shù)決定掃描范圍。例如A表100條,B表200表,需要100次從A表中取出一條數(shù)據(jù)到B表中進(jìn)行200次的比對(duì)。

相對(duì)來說從A表取數(shù)據(jù)消耗的資源比較多。所以盡量tableA選擇比較小的表。同時(shí)縮小B表的查詢范圍。

但是實(shí)際應(yīng)用中,因?yàn)槎叻祷氐臄?shù)據(jù)結(jié)果不同,使用的索引也不同,導(dǎo)致條件放置在on 和 where 效率是不一定誰更好。要根據(jù)需求來確定。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • mysql詳細(xì)分析講解子查詢的使用

    mysql詳細(xì)分析講解子查詢的使用

    子查詢指一個(gè)查詢語句嵌套在另一個(gè)查詢語句內(nèi)部的查詢,這個(gè)特性從 MySQL 4.1開始引入,在SELECT子句中先計(jì)算子查詢,子查詢結(jié)果作為外層另一個(gè)查詢的過濾條件,查詢可以基于一個(gè)表或者多個(gè)表
    2022-04-04
  • MySQL Delete 刪數(shù)據(jù)后磁盤空間未釋放的原因

    MySQL Delete 刪數(shù)據(jù)后磁盤空間未釋放的原因

    這篇文章主要介紹了MySQL Delete 刪數(shù)據(jù)后磁盤空間未釋放的原因,幫助大家更好的理解和學(xué)習(xí)使用MySQL,感興趣的朋友可以了解下
    2021-05-05
  • MySQL中SELECT+UPDATE處理并發(fā)更新問題解決方案分享

    MySQL中SELECT+UPDATE處理并發(fā)更新問題解決方案分享

    這篇文章主要介紹了MySQL中SELECT+UPDATE處理并發(fā)更新問題解決方案分享,需要的朋友可以參考下
    2014-05-05
  • MySQL聯(lián)結(jié)表介紹以及使用詳解

    MySQL聯(lián)結(jié)表介紹以及使用詳解

    這篇文章主要給大家介紹了關(guān)于MySQL聯(lián)結(jié)表介紹及使用的相關(guān)資料,聯(lián)結(jié)SQL最強(qiáng)大的功能之一就是能在數(shù)據(jù)檢索查詢的執(zhí)行中聯(lián)結(jié)表,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-03-03
  • MySQL 在觸發(fā)器里中斷記錄的插入或更新?

    MySQL 在觸發(fā)器里中斷記錄的插入或更新?

    MySQL 不象其它有些數(shù)據(jù)庫可以在觸發(fā)器中拋出異常來中斷當(dāng)然觸發(fā)器的執(zhí)行以阻止相應(yīng)的SQL語句的執(zhí)行。在MySQL的目錄版本中還無法直接拋出異常。這樣我們?nèi)绾螌?shí)現(xiàn)呢?
    2009-07-07
  • centos7環(huán)境下二進(jìn)制安裝包安裝 mysql5.6的方法詳解

    centos7環(huán)境下二進(jìn)制安裝包安裝 mysql5.6的方法詳解

    這篇文章主要介紹了centos7環(huán)境下二進(jìn)制安裝包安裝 mysql5.6的方法,詳細(xì)分析了centos7環(huán)境下使用二進(jìn)制安裝包安裝 mysql5.6的具體步驟、相關(guān)命令、配置方法及操作注意事項(xiàng),需要的朋友可以參考下
    2020-02-02
  • MySQL數(shù)據(jù)庫之內(nèi)置函數(shù)和自定義函數(shù) function

    MySQL數(shù)據(jù)庫之內(nèi)置函數(shù)和自定義函數(shù) function

    這篇文章主要介紹了MySQL數(shù)據(jù)庫之內(nèi)置函數(shù)和自定義函數(shù) function,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下
    2022-06-06
  • MySQL觸發(fā)器學(xué)習(xí)總結(jié)

    MySQL觸發(fā)器學(xué)習(xí)總結(jié)

    創(chuàng)建觸發(fā)器,當(dāng)往order表中添加記錄是,更新goods表,大家可以看下語句即可
    2012-09-09
  • Linux中如何查看mysql版本問題

    Linux中如何查看mysql版本問題

    這篇文章主要介紹了Linux中如何查看mysql版本問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • Mysql8.4.3LTS中離線部署的實(shí)現(xiàn)示例

    Mysql8.4.3LTS中離線部署的實(shí)現(xiàn)示例

    本文詳細(xì)介紹了在Ubuntu 24.04系統(tǒng)上離線部署MySQL 8.4.3 LTS,包括環(huán)境配置、安裝步驟等步驟,對(duì)小白有一定的幫助,感興趣的可以了解一下
    2024-11-11

最新評(píng)論