Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Avoiding IF ELSE due to variable been NULL

I have some code where variable used in the WHERE clause could be nullable. As a result I have to query data using IF ELSE to check for NULL. Is there anyway of writing in in one query?

DECLARE @OrderID UNIQUEIDENTIFIER

IF @OrderID IS NULL 
BEGIN
    SELECT * 
    FROM Customers
    WHERE OrderID IS NULL
END
ELSE
BEGIN
    SELECT * 
    FROM Customers
    WHERE OrderID = @OrderID
END
like image 428
crazy novice Avatar asked Oct 30 '13 13:10

crazy novice


1 Answers

  SELECT * 
  FROM Customers
  WHERE EXISTS (SELECT OrderID INTERSECT SELECT @OrderID)

Will do this efficiently.

See Undocumented Query Plans: Equality Comparisons for more about this.

like image 92
Martin Smith Avatar answered Sep 29 '22 17:09

Martin Smith