掌握MyBatis中动态SQL元素的使用 if choose(when,otherwise) trim where set foreach <SQL>和<include> 在应用中我们经常会做一些动态的拼接条件,但是如果是JDBC我们可以用程序拼接SQL语句,如果MyBatis,我们可以使用动态SQL语句.例如按照员工姓名和工资来搜索员工信息,如果如果姓名和工资的检索值为空,则忽略这个检索条件.一般来说,我们都会用where 1=1类似这种写法来实现,但是MyBatis就需要动态语…
一. 背景 之前mybatis中<where>.<update>.<if>.<foreach>标签用的多,知道有<trim>这个标签,但很少去用,也没有去深入理解它,直到最近遇到一个问题.问题是这样的: 一个SQL有三个int查询字段a.b.c,表达式为:a=#{a} AND (b=#{b} OR c=#{c}).其中a是必查的,b和c为非必查的(这里假定传入-1表示该字段不参与查询).那么该表达式会有以下几种形态: a=#{a} a=#{a}…