گروه مقاله : SQL Server
تاريخ انتشار : 1394/02/02 - 16:13
كد :232
عملگر UNION برای ترکیب دو یا چند عبارت SELECT بکار می رود.
دقت کنید که هر عبارت SELECT داخل UNION باید تعداد ستون یکسان داشته باشد. نوع داده ستون ها نیز باید مشابه باشد.همچنین ترتیب ستون ها در هر عبارت SELECT باید یکسان باشد.
فرم عملگر UNION SQL :
SELECT column_name(s) FROM table1
UNION
SELECT column_name(s) FROM table2;
نکته : عملگر UNION بطور پیش فرض فقط مقادیر مجزا(متفاوت) را انتخاب می کند.برای اینکه مقادیر تکراری داشته باشید از کلمه ALL به همراه UNION استفاده کنید.
فرم عملگر ALL UNION SQL :
SELECT column_name(s) FROM table1
UNION ALL
SELECT column_name(s) FROM table2;
نکته : اسامی ستون ها در جدول نتایج یک UNION معمولا با اسامی ستون ها در اولین عبارت SELECT در UNION برابر است.
نسخه نمایشی پایگاه داده :
در این آموزش ما از نمونه ی پایگاه داده معروف Northwind استفاده می کنیم.
در زیر بخشی از جدول "Customers" آورده شده است :
CustomerID |
CustomerName |
ContactName |
Address |
City |
PostalCode |
Country |
1
|
Alfreds Futterkiste |
Maria Anders |
Obere Str. 57 |
Berlin |
12209 |
Germany |
2 |
Ana Trujillo Emparedados y helados |
Ana Trujillo |
Avda. de la Constitución 2222 |
México D.F. |
05021 |
Mexico |
3 |
Antonio Moreno Taquería |
Antonio Moreno |
Mataderos 2312 |
México D.F. |
05023 |
Mexico |
و بخشی از جدول "Suppliers" :
SupplierID |
SupplierName |
ContactName |
Address |
City |
PostalCode |
Country |
1 |
Exotic Liquid |
Charlotte Cooper |
49 Gilbert St. |
Londona |
EC1 4SD |
UK |
2 |
New Orleans Cajun Delights |
Shelley Burke |
P.O. Box 78934 |
New Orleans |
70117 |
USA |
3 |
Grandma Kelly's Homestead |
Regina Murphy |
707 Oxford Rd. |
Ann Arbor |
48104 |
USA |
مثال UNION SQL :
عبارت SQL زیر تمام شهر های متفاوت (تنها مقادیر مجزا) را از جدول های "Customers" و "Suppliers" انتخاب می کند :
SELECT City FROM Customers
UNION
SELECT City FROM Suppliers
ORDER BY City;
نکته : نمی توان از UNION برای فهرست کردن تمام شهرها از دو جدول استفاده کرد. اگر چندین مشتری و تهیه کننده شهر یکسانی داشته باشند، هر شهر فقط یک بار در لیست خواهد آمد.UNION فقط مقادیر مجزا را انتخاب می کند.اگر می خواهید مقادیر تکراری را هم انتخاب کنید از UNION ALL استفاده کنید.
مثالALL UNION SQL :
عبارت SQL زیر از UNION ALL استفاده می کند تا تمام شهرها (حتی مقادیر تکراری) را از جداول "Customers" و "Suppliers" انتخاب کند:
SELECT City FROM Customers
UNION ALL
SELECT City FROM Suppliers
ORDER BY City;
UNION ALL به همراه WHERE :
عبارت SQL زیر از UNION ALL استفاده می کند تا تمام شهرهای کشور آلمان (حتی مقادیر تکراری) را از جداول "Customers" و "Suppliers" انتخاب کند:
SELECT City, Country FROM Customers
WHERE Country='Germany'
UNION ALL
SELECT City, Country FROM Suppliers
WHERE Country='Germany'
ORDER BY City;