SQL FULL JOIN ¹Ø¼ü×Ö

SQL FULL JOIN ¹Ø¼ü×Ö

Ö»ÒªÆäÖÐij¸ö±í´æÔÚÆ¥Å䣬FULL JOIN ¹Ø¼ü×־ͻ᷵»ØÐС£

FULL JOIN ¹Ø¼ü×ÖÓï·¨

SELECT column_name(s)
FROM table_name1
FULL JOIN table_name2 
ON table_name1.column_name=table_name2.column_name

×¢ÊÍ£ºÔÚijЩÊý¾Ý¿âÖУ¬ FULL JOIN ³ÆÎª FULL OUTER JOIN¡£

ԭʼµÄ±í (ÓÃÔÚÀý×ÓÖеÄ)£º

"Persons" 񡜧

Id_P LastName FirstName Address City
1 Adams John Oxford Street London
2 Bush George Fifth Avenue New York
3 Carter Thomas Changan Street Beijing

"Orders" 񡜧

Id_O OrderNo Id_P
1 77895 3
2 44678 3
3 22456 1
4 24562 1
5 34764 65

È«Á¬½Ó£¨FULL JOIN£©ÊµÀý

ÏÖÔÚ£¬ÎÒÃÇÏ£ÍûÁгöËùÓеÄÈË£¬ÒÔ¼°ËûÃǵ͍µ¥£¬ÒÔ¼°ËùÓе͍µ¥£¬ÒÔ¼°¶¨¹ºËüÃǵÄÈË¡£

Äú¿ÉÒÔʹÓÃÏÂÃæµÄ SELECT Óï¾ä£º

SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo
FROM Persons
FULL JOIN Orders
ON Persons.Id_P=Orders.Id_P
ORDER BY Persons.LastName

½á¹û¼¯£º

LastName FirstName OrderNo
Adams John 22456
Adams John 24562
Carter Thomas 77895
Carter Thomas 44678
Bush George  
    34764

FULL JOIN ¹Ø¼ü×Ö»á´Ó×ó±í (Persons) ºÍÓÒ±í (Orders) ÄÇÀï·µ»ØËùÓеÄÐС£Èç¹û "Persons" ÖеÄÐÐÔÚ±í "Orders" ÖÐûÓÐÆ¥Å䣬»òÕßÈç¹û "Orders" ÖеÄÐÐÔÚ±í "Persons" ÖÐûÓÐÆ¥Å䣬ÕâЩÐÐͬÑù»áÁгö¡£

VUE