中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

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

濉溪县| 台州市| 北票市| 当阳市| 金溪县| 定远县| 庆云县| 盱眙县| 宁海县| 中阳县| 澄江县| 界首市| 大理市| 威海市| 泽州县| 富民县| 镇江市| 彩票| 长沙市| 浑源县| 普安县| 南陵县| 土默特左旗| 岳普湖县| 扎赉特旗| 合江县| 玉门市| 武川县| 新竹市| 佛教| 翁牛特旗| 界首市| 弋阳县| 襄城县| 江北区| 清丰县| 镇江市| 同德县| 施秉县| 泗阳县| 泾源县|