SqlServer多条件组合查询的三种实现方式

  开发中经常会遇得到需要多种条件组合查询的情况,比如有三个表,年级表Grade(GradeId,GradeName),班级Class(ClassId,ClassName,GradeId),学员表Student(StuId,StuName,ClassId),现要求可以按年级Id、班级Id、学生名,这三个条件可以任意组合查询学员信息。

create proc combocondition
    @gradeId int,
    @classId int,
    @stuName nvarchar(10)
as
    select s.*,c.classname,g.gradename from student s join class c on s.classid=c.classid join grade g on c.gradeid=g.gradeid
where
    (@gradeId is null or g.gradeid=@gradeId) and
    (@classId is null or c.classid=@classId) and
    (@stuName is null or s.stuName=@stuName)
go

  那么:

  exec combocondition null,null,null --这是查询所有学员信息;
   
  exec combocondition 2,null,null --这是查询年级Id为2的学员信息;
 
  exec combocondition null,4,null --这是查询班级Id为4的学员信息;

  exec combocondition 2,4,null --这是查询年级Id为2且班级Id为4的学员信息;

  也可以使用case when:

create proc combocondition
    @gradeId int,
    @classId int,
    @stuName nvarchar(10)
as
    select s.*,c.classname,g.gradename from student s join class c on s.classid=c.classid join grade g on c.gradeid=g.gradeid
where
    (case when @gradeId is not null then g.gradeid=@gradeId else 1=1) and
    (case when @classId is not null then g.gradeid=@classId else 1=1) and
    (case when @stuName is not null then g.gradeid=@stuName else 1=1)
go

  也可以拼接SQL字符串:

create proc combocondition
    @gradeId int,
    @classId int,
    @stuName nvarchar(10),
    @SQL 	 nvarchar(4000)
as
begin
set @SQL = '
    select 
    	s.*,c.classname,g.gradename 
    from 
    	student s 
    join 
    	class c on s.classid=c.classid 
    join 
    	grade g on c.gradeid=g.gradeid
  	where
  		1=1
'
if @gradeId is not null and @gradeId <> ''
begin
	set @SQL = @SQL + 'and gradeId =' + ''''+@gradeId+''''
end
if @classId is not null and @classId <> ''
begin
	set @SQL = @SQL + 'and classId =' + ''''+@classId+''''
end
if @stuName is not null and @stuName <> ''
begin
	set @SQL = @SQL + 'and stuName =' + ''''+@stuName+''''
end

print(@SQL)

execute sp_executesql @SQL
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值