可以在@Select注解中使用<if>标签实行动态sql,通俗来说就是,如果存在<if>里的条件,则where按照其中的条件进行查询。当where里的条件可有可无时可以使用,最常见的应用场景就是搜索的时候,比如我要搜书名和出版社,但是有时我只搜书名,或者只搜出版社
代码示例:
@Select({"<script>"+
"select s.salerdeptid,s.salerid,s.salercode,s.salerbankname,"+
"s.salerbanknum,s.salerauditdesc,s.salerauditstate,u.usertruename,d.deptname "+
"from saler s join sysuser u on s.userid=u.userid" +
" join department d on s.salerdeptid=d.deptid "+
"<where>"+
"<if test='usertruename!=null and usertruename!=\"\"'>"+
"and u.usertruename like #{usertruename}"+
"</if>"+
"<if test='salerauditstate!=null'>"+
"and s.salerauditstate=#{salerauditstate}"+
"</if>"+
"</where>"+
"</script>"
})
Page<SalerDto> selectSalerDtoByCon(Page page, SalerDto salerDto, @Param("usertruename") String usertruename,@Param("salerauditstate") Integer salerauditstate);
需要注意的点是:转义字符的使用 ;<if>标签中的and不能大写;if后面的test,不是自己的字段名