where 和 join on有什么區別啊.都能達到同樣的效果.
select * from A a,B b where a.id=b.id;
select * from A a join B b on(a.id=b.id);
都能達到同樣效果.各有什么好處?效率哪個更好?
select * from A a,B b where a.id=b.id;
select * from A a join B b on(a.id=b.id);
都能達到同樣效果.各有什么好處?效率哪個更好?
2015-05-25
舉報
2016-11-06
on后面的是連接條件,代表兩個表建立關系所遵循的規則
where后面的可以看作是篩選條件,是對最終結果集進行過濾所遵循的規則
2015-05-26
這兩種寫法最終產生的結果是相同的。只是SQL標準的不同實現
2019-09-12
第一種是多表查詢,結果集是笛卡爾積,行數是兩個表行數之積,JOIN是在主表的基礎上匹配另一張表,所以如果數據量很大的話,JOIN效率就會比多表查詢高,但是數據量小的話差不多