栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Mybatis自定义SQL的关系映射、分页、排序功能的实现

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Mybatis自定义SQL的关系映射、分页、排序功能的实现

目的: 记录数据库表与实体对象之间不同的映射关系如何用mybatis的自定义sql和结果返回集处理。

1、三种对象映射关系 1.1 一对一

一个人对应一个身份证,一位同学对应一个班级,每个房间都有自己的房间号,当一个事物它对应另一个事物是唯一的,那么它们之间的关系就是一对一的。

这里我演示的案例是,一个学生有着一位老师

老师基础信息:

学生详细信息:

如果说,我们需要将两个表一起查出来,我们可以这么做:

问题: 如果对象的列重复了,必须要使用到别名

1、先定义实体结构,也就是我们返结果的实体类

public class Student {
 @TableId
 private int id;
 private String name;
 private int tid;
 @TableField(exist = false)
 private Teacher teacher;
}

Teacher:

public class Teacher {
 @TableId
 private int id;
 private String name;
}

2、 编写xml文件

这里有两种方式,使用association时的关键在于告诉mybatis如何加载关联(assocition)。

  • 嵌套查询:通过执行另外一个 SQL 映射语句来返回预期的复杂类型。
  • 嵌套结果:使用嵌套结果映射来处理重复的联合结果的子集。

第一种: 使用嵌套查询,也就是使用另一个sql

// teacherMapper.xml



 
 select * from teacher where id = #{id};
 


// studentMapper.xml



 
  SELECT a.*,b.id as cid,b.name as cname FROM `student` as a,teacher as b WHERe a.id =#{id} and a.tid = b.id;
 
 
 
 
 
 
  
  
 
 

我们在相应的mapper中添加方法接口便可以使用了。

1.2 一对多

案例:一个老师有多个学生

1、实体类

public class Teacher {
 @TableId
 private int id;
 private String name;
 @TableField(exist = false)
 private List students;
}

2、编写xml

同样还是,我们先来个嵌套结果映射

嵌套结果:

// teacherMapper.xml
	
 select * from teacher as a where a.id = #{id}

 
 
 
 
 
 
 

	// studentMapper.xml
 
 SELECT * FROM user 
3、自定义sql如何做排序

结论:使用order by,记住要使用'$',不能使用'#'