SQlserver 当输入参数为可选条件
以前很懒,都是用拼接字符串的方式,加上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 后的字符串里不带有通配符时,其作用等同于等号 =
*/
最新文章
- html画布
- 不可或缺 Windows Native (14) - C++: 文件
- mysql中max_allowed_packet参数的配置方法(避免大数据写入或者更新失败)
- Codeforces Round #274 (Div. 1) A. Exams 贪心
- 【Android - MD】之TabLayout的使用
- 12款 jquery轮播插件
- 【Socket计划】使用C++实现Server结束Client结束
- Java笔记(三)
- 富文本NSAttributeString
- 关于sql语句引发的404错误
- BZOJ_1934_[Shoi2007]Vote 善意的投票
- 使用Log4Net进行错误日志记录
- [Tools] Wireshark Primer Tutorials
- UI交互设计关键词:情感化设计与心理
- 类修饰符为abstract与final
- java基础题整理(1)
- svg动态添加小人
- 02-Maven安装配置
- [IOS]开源库RegexKitLite正则表达式的使用
- literallycanvas的简介
热门文章
- python文件头的含义
- Huawei-R&;S-网络工程师实验笔记20190525-设备登录、VRP基本配置、文件系统
- 【CodeCraft-19 and Codeforces Round #537 (Div. 2) C】Creative Snap
- poj 1698
- hdu_1061_Rightmost Digit_201311071851
- source 命令的用法,是在当前bash环境下执行脚本文件
- POJ2777 Count Color 线段树区间更新
- apache禁止訪问某些文件或文件夹的方法
- Oracle学习(一):基本操作和基本查询语句
- iOS7系统iLEX RAT冬青鼠安装教程:无需刷机还原纯净越狱系统