好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > sql連接查詢語句中on、where篩選的區別總結

sql連接查詢語句中on、where篩選的區別總結

熱門標簽:簡單的智能語音電銷機器人 小程序智能電話機器人 ai電話電話機器人 泗洪正規電話機器人找哪家 河北便宜電銷機器人軟件 怎么去開發一個電銷機器人 南昌呼叫中心外呼系統哪家好 怎么申請400熱線電話 湖南保險智能外呼系統產品介紹

前言

相信對于每位程序員來說,sql查詢這個東西, 要說它簡單, 可以很簡單, 通常情況下只需使用增刪查改配合編程語言的邏輯表達能力,就能實現所有功能。 但是增刪查改并不能代表sql語句的所有, 完整的sql功能會另人望而生畏。 就拿比普通增刪查改稍微復雜一個層次的連接查詢來說, 盲目使用, 也會出現意料之外的危險結果,導致程序出現莫名其妙的BUG。

在連接查詢語法中,另人迷惑首當其沖的就要屬on篩選和where篩選的區別了, 在我們編寫查詢的時候, 篩選條件的放置不管是在on后面還是where后面, 查出來的結果總是一樣的, 既然如此,那為什么還要多此一舉的讓sql查詢支持兩種篩選器呢? 事實上, 這兩種篩選器是存在差別的,只是如果不深挖不容易發現而已。

sql中的連接查詢分為3種, cross join,inner join,和outer join , 在 cross join和inner join中,篩選條件放在on后面還是where后面是沒區別的,極端一點,在編寫這兩種連接查詢的時候,只用on不使用where也沒有什么問題。因此,on篩選和where篩選的差別只是針對outer join,也就是平時最常使用的left join和right join。

下面話不多說,來一起看看詳細的介紹:

來看一個示例,有兩張數據表,結構和數據如圖所示

表main

表ext

可以把這兩張表看作是用來存放用戶信息的, main放置主要信息,ext表放置附加信息,兩張表的關系是1對1的,以id字符作為對應關系鍵。現在我們需要將地址不為杭州的所有用戶信息篩選出來,結果中需要包含main表和ext表的所有字段數據。

select * from main left JOIN exton main.id = ext.id and address > '杭州'

閉上眼睛, 請用大腦人肉運行一下這段SQL, 想象一下是什么結果。

當把address > '杭州'這個篩選條件放在on之后,查詢得到的結果似乎跟我們預料中的不同,從結果中能看出,這個篩選條件好像只過濾掉了ext表中對應的記錄,而main表中的記錄并沒有被過濾掉,也就是上圖中標記為紅色的那條記錄。outer join相對于inner join的一個主要特性就是以一側的表為基礎,但是在這里以左表為基這一點卻可以無視篩選條件,這未免也太霸道了一些。

把查詢語句稍微改動一下,將地址的篩選條件從on轉移至where

select * from main left JOIN ext on main.id = ext.id where address > '杭州'

結果就如我們預期的那樣了

造成這種結果上的差異要從outer join查詢的邏輯查詢的各個階段說起。

總的來說,outer join 的執行過程分為4步

      1、先對兩個表執行交叉連接(笛卡爾積)

      2、應用on篩選器

      3、添加外部行

      4、應用where篩選器

就拿上面不使用where篩選器的sql來說,執行的整個詳細過程如下

第一步,對兩個表執行交叉連接,結果如下,這一步會產生36條記錄(此圖顯示不全)

第二步,應用on篩選器。篩選器中有兩個條件,main.id = ext.id and address> '杭州',符合要求的記錄如下

這似乎正是我們期望中查詢的結果,然而在接下來的步驟中這個結果會被打亂

第三步,添加外部行。outer join有一個特點就是以一側的表為基,假如另一側的表沒有符合on篩選條件的記錄,則以null替代。在這次的查詢中,這一步的作用就是將那條原本應該被過濾掉的記錄給添加了回來

是不是不種畫蛇添足的感覺, 結果就成了這樣

第四步,應用where篩選器

在這條問題sql中,因為沒有where篩選器,所以上一步的結果就是最終的結果了。

而對于那條地址篩選在where條件中的sql,這一步便起到了作用,將所有地址不屬于杭州的記錄篩選了出來

通過上面的講解,已經能反應出在outer join中的篩選條件在on中和where中的區別,開發人員如能詳細了解之中差別,能規避很多在編寫sql過程中出現的莫名其妙的錯誤。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • 解析mysql left( right ) join使用on與where篩選的差異
  • MySQL查詢條件中放置on和where的區別分析

標簽:景德鎮 荊門 那曲 柳州 淮安 瀘州 江蘇 威海

巨人網絡通訊聲明:本文標題《sql連接查詢語句中on、where篩選的區別總結》,本文關鍵詞  sql,連接,查詢,語句,中,where,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《sql連接查詢語句中on、where篩選的區別總結》相關的同類信息!
  • 本頁收集關于sql連接查詢語句中on、where篩選的區別總結的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 国模双双大尺度炮交g0go| 久久夜色撩人精品国产小说| 美女被强摸尿口扒开屁股视频| 亚洲AV精品一区二区三区在线| 狠狠挺进鞠婧祎身体小说| 在线观看私人影院| 久久久久婷婷国产综合青草| 说服娇妻尝试其他男人粗大| 一区不卡| 国产一级婬片A视频免费观看| 日本护士献身取精a播放| 97色伦在线影院777www| 天天做天天爱夜夜大爽完整| 操女人网址| 国模冰莲生殖私拍| 免费古装一级婬片潘金莲| 免费?无码?国产在线53| 欧美色性视频| 91精品国产高清久久久久| 久久久91精品国产一区二区三区 | 亚洲经典在线中文字幕| 毛片免费永久不卡视频观看| 伊思人在钱75| 王爷在花轿里就开始圆房的小说| 羞羞视频免费高清观看在线播放| 欧美4K超高清HD| 久久久性| 大尺度肉的小说| 亚洲区视频| NP+虐女+重口+sm+粗口| 内地女明星h放荡系h文小说| 情俗超市| 被黑人c到高潮婬荡呻吟动态图| 欧美丰满白嫩bbw激情| 久久精品秘?一区二区三 | 免费**毛片在线播| 久久无码一区二区爽爽爽公司| 摸麻麻下面她娇喘不停视频| 皮带抽打桃子翘臀sp视频| aaaaa级毛片免费视频| 狂野欧美性猛交xxxx|