使用SQL中case when语句,可以实现我们需要的模糊查询,下面为您介绍SQL case when语句实现模糊查询的脚本,希望对您学习SQL中case when语句的使用有所启示。
成都创新互联公司专注为客户提供全方位的互联网综合服务,包含不限于成都网站设计、做网站、长沙县网络推广、小程序定制开发、长沙县网络营销、长沙县企业策划、长沙县品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;成都创新互联公司为所有大学生创业者提供长沙县建站搭建服务,24小时服务热线:18982081108,官方网址:www.cdcxhl.com
我们在进行项目开发中,经常会遇到多条件模糊查询的需求。对此,我们常见的解决方案有两种:一是在程序端拼接SQL字符串,根据是否选择了某个条件,构造相应的SQL字符串;二是在数据库的存储过程中使用动态的SQL语句。其本质也是拼接SQL字符串,不过是从程序端转移到数据库端而已。
这两种方式的缺点是显而易见的:一是当多个条件每个都可为空时,要使用多个if语句进行判断;二是拼接的SQL语句容易产生SQL注入漏洞。
最近写数据库存储过程的时候经常使用case when 语句,正好可以用这个语句解决一下以上问题。以SQL中的NorthWind数据库为例,我要操作的是其中的Employees表,该表中默认数据如下:
使用如下脚本来查询表中数据:
- 1 DECLARE @FirstName NVARCHAR(10),
- 2 @LastName NVARCHAR(20);
- 3 SELECT @FirstName = '',
- 4 @LastName = '';
- 5 SELECT *
- 6 FROM Employees c
- 7 WHERE CHARINDEX(
- 8 (
- 9 CASE
- 10 WHEN @FirstName = '' THEN FirstName
- 11 ELSE @FirstName
- 12 END
- 13 ),
- 14 FirstName
- 15 ) > 0
- 16 AND CHARINDEX(
- 17 (CASE WHEN @LastName = '' THEN LastName ELSE @LastName END),
- 18 LastName
- 19 ) > 0
【编辑推荐】
SQL中if语句的用法示例
巧用SQL server临时表
速学如何定义SQL存储过程
判断sql server表是否存在的方法
SQL Server表变量和临时表的区别
分享文章:巧用SQL中casewhen语句实现模糊查询
URL分享:http://www.mswzjz.com/qtweb/news36/193486.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联