join過程可以這樣理解:首先兩個表做乙個笛卡爾積,on後面的條件是對這個笛卡爾積做乙個過濾形成一張臨時表,如果沒有where就直接返回結果,如果有where就對上一步的臨時表再進行過濾。下面看實驗:
先準備兩張表:
先執行inner join:
結果沒有區別,前者是先求笛卡爾積然後按照on後面的條件進行過濾,後者是先用on後面的條件過濾,再用where的條件過濾。
再看看左連線left join
這下看出來不對了,id為4的記錄還在,這是由left join的特性決定的,使用left join時on後面的條件只對右表有效(可以看到右表的id=4的記錄沒了)
where的過濾作用就出來了。。。
右連線的原理是一樣的。。
到這裡就真相大白了inner join中on和where沒區別,右連線和左連線就不一樣了。
sql語句中where的引號用法
因為 ip 沒有加單引號 請注意,我們在例子中的條件值周圍使用的是單引號。sql 使用單引號來環繞文字值 大部分資料庫系統也接受雙引號 如果是數值,請不要使用引號。這是正確的 select from persons wherefirstname bush 這是錯誤的 select from pers...
sql語句中的where 1 1
1 1 永真,1 1 永假 1 1 的用處 用於只取結構不取資料的場合 例如 create table table temp tablespace tbs temp as select from table ori where 1 1 建成乙個與table ori 結構相同的表table temp,...
SQL語句中的where 1 1 和0 1
sql where 1 1 和0 1的作用 where 1 1 這個條件始終為true,在不定數量查詢條件情況下,1 1可以很方便的規範語句。string mysqlstr select from table where if age.text.lenght 0 if address.text.le...