您的位置
主页 > 网站技术 > 数据库 > » 正文

SQLServer存储过程中实现多条件查询

来源: 站长圈 点击:

拼接SQL字符串实现多条件查询,以前拼接的写法

set @sql=' select * from table where 1=1 '

if (@addDate is not null)

set @sql = @sql+' and  addDate = '+ @addDate + '  ' 

if (@name <>'' and is not null) 

set @sql = @sql+ ' and name = ' + @name + ' '

exec(@sql)

 

下面是 不采用拼接SQL字符串实现多条件查询的解决方案

 

第一种写法是 感觉代码有些冗余

if (@addDate is not null) and (@name <> '') 

select * from table where addDate = @addDate and name = @name 

else if (@addDate is not null) and (@name ='') 

select * from table where addDate = @addDate 

else if(@addDate is  null) and (@name <> '') 

select * from table where and name = @name 

else if(@addDate is  null) and (@name = '') 

select * from table

 

第二种写法是

 

select * from table where (addDate = @addDate or @addDate is null) and (name = @name or @name = '') 

第三种写法是

 

SELECT * FROM table where 

addDate = CASE @addDate IS NULL THEN addDate ELSE @addDate END, 

name = CASE @name WHEN '' THEN name ELSE @name END




首页  - 关于站长圈  - 广告服务  - 联系我们  - 关于站长圈  - 网站地图  - 版权声明