以前很懒,都是用拼接字符串的方式,加上if 语句,根据输入参数是否为空来判断是否需要在where 后加上对应字段的条件限制
但是拼接字符串很烦,又总是被转义符搞得很烦 ''''
所以想了其他办法
分三种情况(varchar,int,date)都尝试了一下
使用case when 和通配符当主角,而不是'''''''''
不难理解,怕隔天忘记所以记一笔
alter proc sp_testParam
(
@name varchar(50),
@ID int,
@sDate date,
@eDate date
)
as
begin
--懒得要死,老是不乐意去记默认值,所以打印出来望自己长点脑子
print @name+'--name'
print cast(@ID as varchar(50))+'--ID'
print cast(@sDate as varchar(50))+'--sDate'
print cast(@eDate as varchar(50))+'--eDate'
select * from benInfo
where
--varchar,使用'%%'表示包含任何字符串
name like case when @name is null or @name='' then '%%' else '%'+@name+'%' end
--int,使用'[0-9]%'表示包含任何数字,因为该字段是ID,不需要模糊查询,则不需加通配符,完全匹配
and cast(ID as varchar(50)) like case when @ID is null or @ID=0 then '[0-9]%' else cast(@ID as varchar(50)) end
--date,该类型的默认值是'1900-01-01',因此起始日期不用理会,结束日期判断一下,未填则给无限大
and currentDate between @sDate and case when @eDate is null or @eDate='1900-01-01'
then '9999-12-31' else @eDate end
end
--exec sp_testParam '','','','2010-09-03'
至此尝试了一下,在解决简单逻辑时,此方法是可行的
/*
PS.
1.意外发现,当 like 后的字符串里不带有通配符时,其作用等同于等号 =
*/