最近需要使用 xml 文件来实现一些增删改查,此文对 其中的 if-else 加以说明
背景:
有一个引用类,假设叫 Student
java">public class Student {private String name;
private String address;
private Integer yn;}
现在我们查询条件也被封装成一个引用类,例如:
java">public class StudentQueryModel {private String name;
private String address;
private Integer pageIndex;
private Integer pageSize;
private Integer beginIndex;}
那么使用 xml 怎么来使用和接收呢?
首先肯定是在 mapper 里面有一个方法
java"> List<Student> getStudentByCondition(@Param("s") StudentQueryModel model);
然后在 xml 文件中写这个方法的具体实现
xml"><select id="getStudentByCondition"parameterType="入参类型,那么我们这里就应该是 com.xxx.xxx.StudentQueryModel "resultType="返回值类型,注意,我们虽然查询的是一些数据,也就是List,但是这里不能写 java.util.List 而是写 com.xxx..xxx.Student ,如果只想查一条数据,依旧是 com.xxx..xxx.Student ">select * from t_studentWHEREyn = 1
注意,这里最好不要用 <if></if> 标签,写不好就是坑很多,用 choose也是一样的效果<choose><when test=s.name != null and s.name != ''">and t_student.name = #{s.name}</when></choose><choose><when test="s.address != null and s.address != ''">and t_student.address = #{s.address}</when></choose>limit #{s.beginIndex}, #{s.pageSize};//这里最好是在外面算出来,在调用该方法之前就将这两个值算好放到 model 中 不要在这里进行加减乘除的运算,弄不好也有坑</select>