詳解Mysql兩表?join?查詢方式
一、SQL基本語法格式
SELECT DISTINCT < select_list > FROM < left_table > < join_type > JOIN < right_table > ON <join_condition> WHERE < where_condition > GROUP BY < group_by_list > HAVING < having_condition > ORDER BY < order_by_condition > LIMIT < limit_number >
二、3種join方式
1. left join(左連接)
A left join B 得到A表的所有字段,如果沒有匹配到連接條件則用null填充
select A.*,B.* from A left join B on A.id = B.id;
2. right join(右連接)
A right join B 得到B表所有的字段
select A.*,B.* from A right join B on A.id=B.id;
3. inner join(內(nèi)連接)
A inner join B得到(A和B的交集)
select A.*,B.* from A inner join B on A.id=B.id;
4. 在理解上面的三種join下,查詢(A - A∩B)
select A.*,B.* from A left join B on A.id=B.id where B.id is null;
5. 查詢 ( B - A∩B )
select A.*,B.* from A right join B on A.id=B.id where A.id is null;
6. 查詢(A∪B - A∩B)
利用union去重將上面的第四、第五種兩條sql中間用union連接即可完成;即先完成一小部分的,然后將兩個(gè)拼起來的思想。
select A.*,B.* from A left join B on A.id=B.id where B.id is null union select A.*,B.* from A right join B on A.id=B.id where A.id is null;
7. 查詢 AUB
MySQL中求并集可以使用union關(guān)鍵字進(jìn)行處理(自動(dòng)去重)
select A.*,B.* from A left join B on A.id=B.id UNION select A.*,B.* from A right join B on A.id=B.id;
到此這篇關(guān)于Mysql兩表 join 查詢方式的文章就介紹到這了,更多相關(guān)Mysql join 查詢內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mysql8關(guān)閉binlog并清空Binlog的方法
這篇文章主要介紹了mysql8關(guān)閉binlog并清空Binlog,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09MySQl數(shù)據(jù)庫必知必會(huì)sql語句(加強(qiáng)版)
本文給大家分享了一篇關(guān)于mysql數(shù)據(jù)庫必會(huì)sql語句加強(qiáng)版內(nèi)容,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧2017-04-04MySql創(chuàng)建帶解釋的表及給表和字段加注釋的實(shí)現(xiàn)代碼
這篇文章主要介紹了MySql創(chuàng)建帶解釋的表以及給表和字段加注釋的實(shí)現(xiàn)方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-12-12MySQL查詢隨機(jī)數(shù)據(jù)的4種方法和性能對(duì)比
從MySQL隨機(jī)選取數(shù)據(jù)也是我們最常用的一種發(fā)發(fā),其最簡(jiǎn)單的辦法就是使用”O(jiān)RDER BY RAND()”,本文介紹了包括ORDER BY RAND()的4種獲取隨機(jī)數(shù)據(jù)的方法,并分析了各自的優(yōu)缺點(diǎn)。2014-04-04

mysql配置連接參數(shù)設(shè)置及性能優(yōu)化