以前很懒,都是用拼接字符串的方式,加上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 后的字符串里不带有通配符时,其作用等同于等号 =

*/

最新文章

  1. html画布
  2. 不可或缺 Windows Native (14) - C++: 文件
  3. mysql中max_allowed_packet参数的配置方法(避免大数据写入或者更新失败)
  4. Codeforces Round #274 (Div. 1) A. Exams 贪心
  5. 【Android - MD】之TabLayout的使用
  6. 12款 jquery轮播插件
  7. 【Socket计划】使用C++实现Server结束Client结束
  8. Java笔记(三)
  9. 富文本NSAttributeString
  10. 关于sql语句引发的404错误
  11. BZOJ_1934_[Shoi2007]Vote 善意的投票
  12. 使用Log4Net进行错误日志记录
  13. [Tools] Wireshark Primer Tutorials
  14. UI交互设计关键词:情感化设计与心理
  15. 类修饰符为abstract与final
  16. java基础题整理(1)
  17. svg动态添加小人
  18. 02-Maven安装配置
  19. [IOS]开源库RegexKitLite正则表达式的使用
  20. literallycanvas的简介

热门文章

  1. python文件头的含义
  2. Huawei-R&S-网络工程师实验笔记20190525-设备登录、VRP基本配置、文件系统
  3. 【CodeCraft-19 and Codeforces Round #537 (Div. 2) C】Creative Snap
  4. poj 1698
  5. hdu_1061_Rightmost Digit_201311071851
  6. source 命令的用法,是在当前bash环境下执行脚本文件
  7. POJ2777 Count Color 线段树区间更新
  8. apache禁止訪问某些文件或文件夹的方法
  9. Oracle学习(一):基本操作和基本查询语句
  10. iOS7系统iLEX RAT冬青鼠安装教程:无需刷机还原纯净越狱系统