TOP

SQL CASE

وصف SQL CASE

يبحث تعبير CASE SQL في الشروط ويعيد قيمة عند استيفاء الشرط الأول (على سبيل المثال، عبارة if-then-else). لذلك، بمجرد استيفاء الشرط، ستتوقف التعليمات عن القراءة وتعيد النتيجة. إذا لم يتم استيفاء أي شرط، يتم إرجاع القيمة الموجودة في جملة ELSE.

إذا لم يكن هناك أي جزء من ELSE ولم يتم استيفاء الشروط، فسيتم إرجاع NULL.


CASE بناء الجملة

SELECT column1, column2, ...
CASE 
    WHEN condition1 THEN result1
    WHEN condition2 THEN result2
    WHEN conditionN THEN resultN
    ELSE result
END

قاعدة البيانات التوضيحية

ما يلي هو نموذج من الجدول "OrderDetails" لقاعدة البيانات "Northwind":

OrderDetailIDOrderIDProductIDQuantity
1102481112
2102484210
310248725
410249149
5102495140

أمثلة SQL CASE

تتحقق عبارة SQL التالية من الشروط وترجع قيمة عند استيفاء الشرط الأول:

Run SQLSELECT OrderID, Quantity,
CASE
    WHEN Quantity > 30 THEN 'The quantity is greater than 30'
    WHEN Quantity = 30 THEN 'The quantity is 30'
    ELSE 'The quantity is under 30'
END AS QuantityText
FROM OrderDetails

يقوم استعلام SQL هذا بفرز العملاء حسب المدينة (City). ومع ذلك، إذا كانت المدينة هي NULL، فقم بالفرز حسب البلد (Country):

Run SQLSELECT CustomerName, City, Country
FROM Customers
ORDER BY
(CASE
    WHEN City IS NULL THEN Country
    ELSE City
END)