Я работаю с хранимой процедурой в SQL Server 2005. Можно ли использовать объединение, если только параметр не равен NULL?Ниже приведен пример запроса:
ALTER PROCEDURE [dbo].[SPSample]
@gender varchar(20) = null
@username varchar(20) = null
AS
SELECT
per.firstName,
per.lastName,
per.gender
FROM person per
INNER JOIN account ac on ac.idPerson = per.idPerson
WHERE (
gender = @gender
AND (@username is null or (@username is not null and @username = acc.username))
Как заставить INNER JOIN
работать, только если @username
не равно нулю?Каков наилучший подход для получения ожидаемого результата?