CASE ranking
WHEN 1 THEN 'alpha'
WHEN 2 THEN 'beta'
WHEN 10 THEN 'charlie'
ELSE 'zelta'
END CASE;
Sie können einen der Ausdrücke verwenden, die WHEN hat, aber Sie können nicht beide mischen.
1) WHEN when_expressionIst ein einfacher Ausdruck, mit dem input_expression verglichen wird, wenn das einfache CASE-Format verwendet wird. when_expression ist ein beliebiger gültiger Ausdruck. Die Datentypen von input_expression und jedem when_expression müssen gleich sein oder müssen eine implizite Konvertierung sein.
2) WHEN Boolean_expressionIst der boolesche Ausdruck, der ausgewertet wird, wenn das gesuchte CASE-Format verwendet wird. Boolescher_Ausdruck ist ein beliebiger gültiger boolescher Ausdruck.
Sie könnten Folgendes programmieren:
1)
CASE ProductLine
WHEN 'R' THEN 'Road'
WHEN 'M' THEN 'Mountain'
WHEN 'T' THEN 'Touring'
WHEN 'S' THEN 'Other sale items'
ELSE 'Not for sale'
2)
CASE
WHEN ListPrice = 0 THEN 'Mfg item - not for resale'
WHEN ListPrice < 50 THEN 'Under $50'
WHEN ListPrice >= 50 and ListPrice < 250 THEN 'Under $250'
WHEN ListPrice >= 250 and ListPrice < 1000 THEN 'Under $1000'
ELSE 'Over $1000'
END
Aber in jedem Fall können Sie erwarten, dass die Rangfolge der Variablen in einem booleschen Ausdruck verglichen wird.
http://msdn.microsoft.com/en-us/library/ms181765 .aspx