主要來(lái)介紹下Inner Join , Full Out Join , Cross Join , Left Join , Right Join的區(qū)別。
Inner Join:篩選兩邊都有的記錄
Full Out Join:兩邊都篩選出來(lái),匹配能匹配的,不能匹配的用NULL列出
Cross Join:列出兩邊所有組合,也稱為笛卡爾集 A×B
Left Join:以左邊的表為主表,列出主表所有記錄,匹配能匹配的,不能匹配的用 NULL列出
Right Join:以右邊的表為主表,列出主表所有記錄,匹配能匹配的,不匹配的用NULL列出
下面來(lái)看代碼:
創(chuàng)建測(cè)試表:
CREATETABLE CONSUMERS (CONSUMER_ID INTNOTNULL,CONSUMER_NAME VARCHAR(10) NOTNULL)CREATETABLE ORDERS(CONSUMER_ID INTNOTNULL, ORDER_ID VARCHAR(10) NOTNULL)
編測(cè)試數(shù)據(jù)
INSERT CONSUMERS VALUES ( 1, 'AA')INSERT CONSUMERS values ( 2, 'BB')INSERT CONSUMERS values ( 3, 'CC')INSERT ORDERS VALUES ( 2, 'O100001')INSERT ORDERS VALUES ( 3, 'O100002')INSERT ORDERS VALUES ( 3, 'O100003')INSERT ORDERS VALUES ( 4, 'O100004')
測(cè)試
--Inner Join--篩選兩邊都有的記錄SELECT *FROM ORDERS o INNER JOIN CONSUMERS cON o.CONSUMER_ID = c.CONSUMER_ID--Full Out Join--兩邊都篩選出來(lái),匹配能匹配的,不能匹配的用NULL列出SELECT *FROM ORDERS o FULL OUTER JOIN CONSUMERS cON o.CONSUMER_ID = c.CONSUMER_ID--Cross Join--列出兩邊所有組合,即笛卡爾集A×BSELECT *FROM ORDERS o CROSS JOIN CONSUMERS c--Left Join--以左邊的表為主表,列出主表所有記錄,匹配能匹配的,不能匹配的用NULL列出SELECT * FROM CONSUMERS c left join ORDERS oon c .CONSUMER_ID = o .CONSUMER_ID--Right Join--以右邊的表為主表,列出主表所有記錄,匹配能匹配的,不能匹配的用NULL列出SELECT * FROM CONSUMERS c RIGHT JOIN ORDERS oon c .CONSUMER_ID = o .CONSUMER_ID
ok了,具體的大家可以參考VeVb武林網(wǎng)以前發(fā)布的文章。
新聞熱點(diǎn)
疑難解答
圖片精選