亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SQL中的on條件與where條件有什么區別

發布時間:2021-08-31 11:26:40 來源:億速云 閱讀:101 作者:chen 欄目:編程語言

本篇內容主要講解“SQL中的on條件與where條件有什么區別”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“SQL中的on條件與where條件有什么區別”吧!

在使用leftjoin時,on和where條件的區別如下:

  1、on條件是在生成臨時表時使用的條件,它不管on中的條件是否為真,都會返回左邊表中的記錄。

  2、where條件是在臨時表生成好后,再對臨時表進行過濾的條件。這時已經沒有leftjoin的含義(必須返回左邊表的記錄)了,條件不為真的就全部過濾掉。

  假設有兩張表:

  表1:tab1

  idsize

  110

  220

  330

  表2:tab2

  sizename

  10AAA

  20BBB

  20CCC

兩條SQL:

  1、select*fromtab1leftjointab2ontab1.size=tab2.sizewheretab2.name='AAA'

  2、select*fromtab1leftjointab2ontab1.size=tab2.sizeandtab2.name='AAA'

第一條SQL的過程:

  1、中間表

  on條件:

  tab1.size=tab2.size

  tab1.idtab1.sizetab2.sizetab2.name

  11010AAA

  22020BBB

  22020CCC

  330(null)(null)

  2、再對中間表過濾

  where條件:

  tab2.name='AAA'

  tab1.idtab1.sizetab2.sizetab2.name

  11010AAA

第二條SQL的過程:

  1、中間表

  on條件:

  tab1.size=tab2.sizeandtab2.name='AAA'

  (條件不為真也會返回左表中的記錄)tab1.idtab1.sizetab2.sizetab2.name

  11010AAA

  220(null)(null)

  330(null)(null)

  其實以上結果的關鍵原因就是leftjoin,rightjoin,fulljoin的特殊性。

  不管on上的條件是否為真都會返回left或right表中的記錄,full則具有left和right的特性的并集。

  而innerjion沒這個特殊性,則條件放在on中和where中,返回的結果集是相同的。

到此,相信大家對“SQL中的on條件與where條件有什么區別”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

sql
AI

三门峡市| 赞皇县| 故城县| 鹿邑县| 远安县| 宜兴市| 舞钢市| 涿州市| 南郑县| 罗田县| 裕民县| 桃江县| 襄垣县| 昭觉县| 大港区| 化州市| 河西区| 开封市| 大方县| 城步| 永康市| 梁平县| 象山县| 平山县| 南乐县| 罗山县| 长沙县| 高青县| 特克斯县| 井陉县| 土默特右旗| 当阳市| 乐平市| 龙岩市| 竹北市| 晋宁县| 侯马市| 巢湖市| 雅江县| 江华| 溧水县|