آموزش FULL OUTER JOIN در SQL Server کشف داده‌های کامل و گمشده

FULL OUTER JOIN در SQL Server: کشف قدرت ادغام کامل داده‌ها و یافتن گمشده‌ها

وقتی صحبت از ادغام داده‌ها در پایگاه‌های داده SQL Server می‌شود، اغلب توسعه‌دهندگان به سراغ `INNER JOIN` و `LEFT JOIN` می‌روند. اما گاهی اوقات، یک ابزار قدرتمندتر به نام `FULL OUTER JOIN` نادیده گرفته می‌شود. این نوع `JOIN` منحصر به فرد به شما امکان می‌دهد تمام سطرها را از هر دو جدول مرتبط بازیابی کنید، چه در جدول دیگر مطابقت داشته باشند و چه نداشته باشند. درک و استفاده صحیح از `FULL OUTER JOIN` برای سناریوهایی که نیاز به دید جامع از داده‌های مرتبط و غیرمرتبط دارید، حیاتی است و می‌تواند به شما در شناسایی ناهماهنگی‌ها و نقاط ضعف در داده‌هایتان کمک کند.

برای درک بهتر `FULL OUTER JOIN`، ابتدا نگاهی سریع به عملگرهای `JOIN` متداول‌تر می‌اندازیم.

**مروری بر INNER JOIN**
`INNER JOIN` تنها ردیف‌هایی را از دو جدول برمی‌گرداند که مقادیر تطابق یافته در هر دو جدول بر اساس شرط `JOIN` مشخص شده داشته باشند. به عبارت دیگر، این `JOIN` فقط اشتراکات را نشان می‌دهد.

مثال عملی: اگر بخواهیم نام کارمندان و دپارتمان‌هایشان را تنها برای کارمندانی که حتماً دپارتمان دارند (و دپارتمان‌هایی که حتماً کارمند دارند) بازیابی کنیم، از `INNER JOIN` استفاده می‌کنیم.


SELECT E.EmployeeName, D.DepartmentName
FROM Employees AS E
INNER JOIN Departments AS D ON E.DepartmentID = D.DepartmentID;

در این کوئری `INNER JOIN`، تنها کارمندانی نمایش داده می‌شوند که `DepartmentID` آن‌ها با `DepartmentID` موجود در جدول `Departments` مطابقت داشته باشد.

**مروری بر LEFT JOIN (LEFT OUTER JOIN)**
`LEFT JOIN` (که می‌توان آن را `LEFT OUTER JOIN` نیز نامید) تمام سطرها را از جدول سمت چپ و سطر‌های مطابق را از جدول سمت راست برمی‌گرداند. اگر هیچ تطابقی در جدول سمت راست یافت نشود، مقادیر `NULL` برای ستون‌های جدول سمت راست بازگردانده می‌شود. این نوع `JOIN` برای زمانی مفید است که می‌خواهید همه چیز را از یک جدول ببینید و اطلاعات مرتبط از جدول دیگر را به آن اضافه کنید.

مثال: برای مشاهده تمام کارمندان، حتی اگر دپارتمانی نداشته باشند، و دپارتمان‌های مربوطه آن‌ها:


SELECT E.EmployeeName, D.DepartmentName
FROM Employees AS E
LEFT OUTER JOIN Departments AS D ON E.DepartmentID = D.DepartmentID;

این کوئری تمام کارمندان را نشان می‌دهد، و اگر کارمندی `DepartmentID` منطبقی در جدول `Departments` نداشته باشد، `DepartmentName` آن `NULL` خواهد بود.

**مروری بر RIGHT JOIN (RIGHT OUTER JOIN)**
`RIGHT JOIN` (یا `RIGHT OUTER JOIN`) دقیقاً برعکس `LEFT JOIN` عمل می‌کند. این `JOIN` تمام سطرها را از جدول سمت راست و سطر‌های مطابق را از جدول سمت چپ برمی‌گرداند. اگر هیچ تطابقی در جدول سمت چپ یافت نشود، مقادیر `NULL` برای ستون‌های جدول سمت چپ بازگردانده می‌شود. این `JOIN` برای مشاهده تمام موارد از جدول سمت راست و اضافه کردن اطلاعات مرتبط از جدول سمت چپ مفید است.

مثال: برای مشاهده تمام دپارتمان‌ها، حتی اگر کارمندی در آن‌ها نباشد، و کارمندان مربوطه آن‌ها:


SELECT E.EmployeeName, D.DepartmentName
FROM Employees AS E
RIGHT OUTER JOIN Departments AS D ON E.DepartmentID = D.DepartmentID;

این کوئری تمام دپارتمان‌ها را نمایش می‌دهد، و اگر دپارتمانی کارمند منطبقی در جدول `Employees` نداشته باشد، `EmployeeName` آن `NULL` خواهد بود.

**آشنایی با FULL OUTER JOIN**
`FULL OUTER JOIN` (که می‌توان آن را `FULL JOIN` نیز نامید) یک عملگر `JOIN` قدرتمند در SQL Server است که ترکیبی از `LEFT JOIN` و `RIGHT JOIN` را ارائه می‌دهد. این `JOIN` تمام سطرها را از هر دو جدول مرتبط برمی‌گرداند، چه در جدول دیگر تطابق داشته باشند و چه نداشته باشند. اگر تطابقی وجود نداشته باشد، مقادیر `NULL` برای ستون‌های جدول بدون تطابق بازگردانده می‌شود. `FULL OUTER JOIN` برای مواقعی ایده‌آل است که می‌خواهید یک نمای کامل از تمام داده‌های ممکن، از هر دو طرف رابطه، به همراه هر گونه عدم تطابق را به دست آورید. این عملگر به شما کمک می‌کند تا داده‌های گمشده یا ناسازگاری‌ها را در مجموعه داده‌های خود شناسایی کنید.

مثال: برای مشاهده تمام کارمندان و تمام دپارتمان‌ها، حتی اگر برخی از آن‌ها تطابقی نداشته باشند:


SELECT E.EmployeeName, D.DepartmentName
FROM Employees AS E
FULL OUTER JOIN Departments AS D ON E.DepartmentID = D.DepartmentID;

در این سناریو، شما تمام کارمندان را خواهید دید (حتی آن‌هایی که `DepartmentID` آن‌ها `NULL` است یا با هیچ دپارتمانی مطابقت ندارد) و تمام دپارتمان‌ها را (حتی آن‌هایی که هیچ کارمندی ندارند).

**یافتن ردیف‌های غیر منطبق با FULL OUTER JOIN**
یکی از کاربردهای مهم `FULL OUTER JOIN`، شناسایی ردیف‌هایی است که در یک جدول وجود دارند اما در جدول دیگر معادل ندارند. این بسیار مفید است برای کشف داده‌های “بی‌صاحب” یا “گمشده” که ممکن است نشان‌دهنده مشکلات یکپارچگی داده‌ها باشند.

برای مثال، فرض کنید می‌خواهیم تمام کارمندانی را که دپارتمانی ندارند *یا* تمام دپارتمان‌هایی را که کارمندی ندارند، پیدا کنیم. این کار با افزودن یک شرط `WHERE` به `FULL OUTER JOIN` امکان‌پذیر است.


SELECT E.EmployeeName, D.DepartmentName
FROM Employees AS E
FULL OUTER JOIN Departments AS D ON E.DepartmentID = D.DepartmentID
WHERE E.EmployeeID IS NULL OR D.DepartmentID IS NULL;

این کوئری به طور خاص ردیف‌هایی را هدف قرار می‌دهد که نشان‌دهنده عدم وجود تطابق در یک یا هر دو جدول هستند. `E.EmployeeID IS NULL` ردیف‌های `Department` را برمی‌گرداند که هیچ کارمند تطابقی ندارند، در حالی که `D.DepartmentID IS NULL` ردیف‌های `Employee` را برمی‌گرداند که هیچ دپارتمان تطابقی ندارند.

**نتیجه‌گیری**
`FULL OUTER JOIN` ابزاری قدرتمند و اغلب دست‌کم گرفته شده در مجموعه مهارت‌های هر متخصص SQL Server است. این `JOIN` با فراهم کردن دیدی جامع از تمام داده‌های مرتبط و غیرمرتبط در دو جدول، می‌تواند به شما در تجزیه و تحلیل عمیق‌تر، کشف ناهماهنگی‌های داده‌ها و حفظ یکپارچگی پایگاه داده کمک کند. درک زمان و نحوه استفاده از `FULL OUTER JOIN` می‌تواند به طور قابل توجهی قابلیت‌های شما در کوئری نویسی و مدیریت داده‌ها را افزایش دهد و شما را قادر سازد تا راه‌حل‌های داده‌ای دقیق‌تر و کامل‌تری ارائه دهید. از این ابزار غافل نشوید تا بتوانید به بهترین شکل ممکن با داده‌های خود کار کنید.

join
Comments (0)
Add Comment