欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SQL中過濾條件放on和where中的區(qū)別詳解

 更新時間:2019年01月25日 11:46:16   作者:古月慕南  
這篇文章主要給大家介紹了關(guān)于SQL中過濾條件放on和where中的區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起看看吧

前言

今天接到螞蟻金服的電面,問了sql中過濾條件放在on和where中的區(qū)別,當時滿腦子是inner join,覺得沒區(qū)別啊。后來才想起來,連接查詢除了inner join還有right join,left join。汗吶,當時還是太緊張了。這里做一下記錄吧。

join過程可以這樣理解:首先兩個表做一個笛卡爾積,on后面的條件是對這個笛卡爾積做一個過濾形成一張臨時表,如果沒有where就直接返回結(jié)果,如果有where就對上一步的臨時表再進行過濾。下面看實驗:

先準備兩張表:

先執(zhí)行inner join:

select * from person p inner join account a on p.id=a.id and p.id!=4 and a.id!=4;

select * from person p inner join account a on p.id=a.id where p.id!=4 and a.id!=4;

結(jié)果沒有區(qū)別,前者是先求笛卡爾積然后按照on后面的條件進行過濾,后者是先用on后面的條件過濾,再用where的條件過濾。

再看看左連接left join

select * from person p left join account a on p.id=a.id and p.id!=4 and a.id!=4;

這下看出來不對了,id為4的記錄還在,這是由left join的特性決定的,使用left join時on后面的條件只對右表有效(可以看到右表的id=4的記錄沒了)

select * from person p left join account a on p.id=a.id where p.id!=4 and a.id!=4;


where的過濾作用就出來了。。。

右連接的原理是一樣的。。

到這里就真相大白了inner join中on和where沒區(qū)別,右連接和左連接就不一樣了。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • NoSQL 數(shù)據(jù)庫你應(yīng)該了解的 10 件事

    NoSQL 數(shù)據(jù)庫你應(yīng)該了解的 10 件事

    NoSQL 數(shù)據(jù)庫通常使用廉價服務(wù)器集群去管理迅猛發(fā)展的數(shù)據(jù)和交易容量,而 RDBMS 傾向依賴昂貴的專業(yè)服務(wù)器和存儲系統(tǒng)。結(jié)果就是,NoSQL 系統(tǒng)的每千兆字節(jié)成本或者每秒的交易成本要很多倍的低于 RDBMS 系統(tǒng),這使得你可以非常低的成本去存儲和處理更多的數(shù)據(jù)。
    2016-04-04
  • 詳細聊聊sql中exists和not?exists用法

    詳細聊聊sql中exists和not?exists用法

    mysql exists或not exists語句用于子查詢,改語句只返回 TRUE 或 FALSE,下面這篇文章主要給大家介紹了關(guān)于sql中exists和not?exists用法的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-02-02
  • 數(shù)據(jù)庫的三級模式和兩級映射介紹

    數(shù)據(jù)庫的三級模式和兩級映射介紹

    在這里大家一定要注意三級模式中的概念模式對應(yīng)的是數(shù)據(jù)庫設(shè)計的邏輯模型,而不是概念模型(E-R模型),一定不要弄混了
    2012-10-10
  • SQL中Having與Where的區(qū)別

    SQL中Having與Where的區(qū)別

    何時使用having where,請遵照下面的說明:WHERE語句在GROUP BY語句之前;SQL會在分組之前計算WHERE語句。HAVING語句在GROUP BY語句之后;SQL會在分組之后計算HAVING語句。
    2016-01-01
  • 特殊的存儲過程-觸發(fā)器概述

    特殊的存儲過程-觸發(fā)器概述

    一直都不知道觸發(fā)器的具體應(yīng)用,今天看到一篇觸發(fā)器的解釋文章
    2008-04-04
  • 利用DataSet部分功能實現(xiàn)網(wǎng)站登錄

    利用DataSet部分功能實現(xiàn)網(wǎng)站登錄

    這篇文章主要介紹了利用DataSet部分功能實現(xiàn)網(wǎng)站登錄 ,需要的朋友可以參考下
    2017-05-05
  • 如何讓SQL運行得更快

    如何讓SQL運行得更快

    如何讓SQL運行得更快...
    2007-01-01
  • 如何利用分析函數(shù)改寫范圍判斷自關(guān)聯(lián)查詢詳解

    如何利用分析函數(shù)改寫范圍判斷自關(guān)聯(lián)查詢詳解

    這篇文章主要給大家介紹了關(guān)于如何利用分析函數(shù)改寫范圍判斷自關(guān)聯(lián)查詢的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用sql具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-10-10
  • 通過DBeaver連接Phoenix操作hbase的方法

    通過DBeaver連接Phoenix操作hbase的方法

    DBeaver?可通過?JDBC?連接到數(shù)據(jù)庫,可以支持幾乎所有的數(shù)據(jù)庫產(chǎn)品,本文介紹常用一種通用數(shù)據(jù)庫工具Dbeaver,通過DBeaver連接Phoenix操作hbase的操作,需要的朋友跟隨小編一起看看吧
    2021-11-11
  • SQL中過濾條件放on和where中的區(qū)別詳解

    SQL中過濾條件放on和where中的區(qū)別詳解

    這篇文章主要給大家介紹了關(guān)于SQL中過濾條件放on和where中的區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起看看吧
    2019-01-01

最新評論