最近需要使用 xml 文件来实现一些增删改查,此文对 其中的 if-else 加以说明
背景:
有一个引用类,假设叫 Student
public class Student {
private String name;
private String address;
private Integer yn;
}
现在我们查询条件也被封装成一个引用类,例如:
public class StudentQueryModel {
private String name;
private String address;
private Integer pageIndex;
private Integer pageSize;
private Integer beginIndex;
}
那么使用 xml 怎么来使用和接收呢?
首先肯定是在 mapper 里面有一个方法文章来源:https://www.toymoban.com/news/detail-855947.html
List<Student> getStudentByCondition(@Param("s") StudentQueryModel model);
然后在 xml 文件中写这个方法的具体实现文章来源地址https://www.toymoban.com/news/detail-855947.html
<select id="getStudentByCondition"
parameterType="入参类型,那么我们这里就应该是 com.xxx.xxx.StudentQueryModel "
resultType="返回值类型,注意,我们虽然查询的是一些数据,也就是List,但是这里不能写 java.util.List 而是写 com.xxx..xxx.Student ,如果只想查一条数据,依旧是 com.xxx..xxx.Student ">
select * from t_student
WHERE
yn = 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>
到了这里,关于mybatis使用xml中的if-else/choose的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!