I have a table something like
EMPLOYEE_ID DTL_ID COLUMN_A COLUMN_B
---------------------------
JOHN 0 1 1
JOHN 1 3 1
LINN 0 1 12
SMITH 0 9 1
SMITH 1 11 12
It means for each person there will be one or more records with different DTL_ID‘s value (0, 1, 2 .. etc).
Now I’d like to create a T-SQL statement to retrieve the records with EMPLOYEE_ID and DTL_ID.
If the specified DTL_ID is NOT found, the record with DTL_ID=0 will be returned.
I know that I can achieve this in various ways such as checking if a row exists via EXISTS or COUNT(*) first and then retrieve the row.
However, I’d like to know other possible ways because this retrieval statement is very common in my application and my table have hundred thousand of rows.
In the above approach, I’ve had to retrieve twice even if the record with the DTL_ID specified exists, and I want to avoid this.
Like this:
You will of course have to fill in the ?? with the proper number.