关于多条件查询的时候如何使用动态sql语句

我们在进行查询操作的时候会有根据多个参数来查询的情况,查询语句一样,但是条件不一致,这个时候使用动态sql语句就可以非常方便的帮助我们实现多条件查询,下面是我在开发中遇到的一个例子(sql语句可以直接看第4步,前面写的是接收过程):

1.可以先看一下我的查询页面,是根据姓名,班级组成的多个不同的条件来进行查询的,我们可以只输入姓名查询,也可以只选择班级查询,也可以两个条件都加上,使用动态sql语句的话只需要一条查询语句就可以完成多种不同条件的查询:

在这里插入图片描述

2.controller层接收传来的参数,把所有的条件参数无论是空还是有值的情况都传到我们的控制层接收,timeteach, cnamecid, stuname,接收到这三个参数后调用service层的对应方法:

@RequestMapping("tostushow")
	public String stushow(String uname,String stuname,Integer cnamecid,HttpServletRequest req){
		//将接收的参数调用service层的方法
		List<Students> list = teachMainService.getStuAll(timeteach, cnamecid, stuname,pageNum,pageSize);
		req.setAttribute("list ", list );
		return "stushow";
	}

3.通过service最终到dao层,dao层执行的是mapper映射文件里的sql查询语句,这里要注意的一点是如果是传递多个参数,在dao层需要在参数前面加上@Param(“name”)注解:

public List<Students> selectStuAll(@Param("timeteach") Integer timeteach,@Param("cid") Integer cnamecid,@Param("stuname") String stuname);

4.最后就是执行我们的动态sql语句了,这里我是多表连接查询,可以重点看where标签里面的部分就是我们的动态sql语句实现方法,where标签包裹就是代表数据库中的where关键字:里面用 if 来判断传来的参数,如果参数不为空,就拼接上里面的条件,如果为空就不拼接,这样就完成了我们的多条件动态sql查询

<select id="selectStuAll" resultMap="stumap">
		SELECT distinct a.stuname,a.stunum,a.stuage,a.stusex,a.sturemarks,a.stuimg,a.stuhome,b.cname,c.timeteach
		 FROM `students` a left join clazz b on a.stuclazz = b.cid
		inner join clazztime c on b.cid = c.timeclzid
		<where>
			<if test="timeteach != null and timeteach != ''">
				and timeteach = #{timeteach}
			</if>
			<if test="cid != null">
				and b.cid = #{cid}
			</if>
			<if test="stuname != null">
				and a.stuname like concat('%',#{stuname},'%')
			</if>
		</where>
	</select>
  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值