MyBatis图文并茂讲解注解开发多对多查询
作者:流楚丶格念 时间:2022-10-27 17:05:04
MyBatis的注解实现复杂映射开发
实现复杂关系映射之前我们可以在映射文件中通过配置来实现,使用注解开发后,我们可以使用@Results注解,@Result注解,@One注解,@Many注解组合完成复杂关系的配置
多对多查询
多对多查询的模型
多对多查询的需求:查询学生以及所对应的课程信息
多对多查询的语句
对应的sql语句:
SELECT DISTINCT s.id,s.name,s.age FROM student s,stu_cr sc WHERE sc.sid=s.id
SELECT c.id,c.name FROM stu_cr sc,course c WHERE sc.cid=c.id AND sc.sid=#{id}
添加CourseMapper 接口方法
public interface CourseMapper {
//根据学生id查询所选课程
@Select("SELECT c.id,c.name FROM stu_cr sc,course c WHERE sc.cid=c.id AND sc.sid=#{id}")
public abstract List<Course> selectBySid(Integer id);
}
使用注解配置Mapper
public interface StudentMapper {
//查询全部
@Select("SELECT DISTINCT s.id,s.name,s.age FROM student s,stu_cr sc WHERE sc.sid=s.id")
@Results({
@Result(column = "id",property = "id"),
@Result(column = "name",property = "name"),
@Result(column = "age",property = "age"),
@Result(
property = "courses", // 被包含对象的变量名
javaType = List.class, // 被包含对象的实际数据类型
column = "id", // 根据查询出student表的id来作为关联条件,去查询中间表和课程表
/*
many、@Many 一对多查询的固定写法
select属性:指定调用哪个接口中的哪个查询方法
*/
many = @Many(select = "com.yyl.many_to_many.CourseMapper.selectBySid")
)
})
public abstract List<Student> selectAll();
}
测试类
public class Test01 {
@Test
public void selectAll() throws Exception{
//1.加载核心配置文件
InputStream is = Resources.getResourceAsStream("MyBatisConfig.xml");
//2.获取SqlSession工厂对象
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
//3.通过工厂对象获取SqlSession对象
SqlSession sqlSession = sqlSessionFactory.openSession(true);
//4.获取StudentMapper接口的实现类对象
StudentMapper mapper = sqlSession.getMapper(StudentMapper.class);
//5.调用实现类对象中的方法,接收结果
List<Student> list = mapper.selectAll();
//6.处理结果
for (Student student : list) {
System.out.println(student.getId() + "," + student.getName() + "," + student.getAge());
List<Course> courses = student.getCourses();
for (Course cours : courses) {
System.out.println("\t" + cours);
}
}
//7.释放资源
sqlSession.close();
is.close();
}
}
运行结果如下:
多对多配置总结
注解 | 说明 |
---|---|
@Results | 封装映射关系的父注解。 Result[] value():定义了 Result 数组 |
@Result | 封装映射关系的子注解。 column 属性:查询出的表中字段名称 property 属性:实体对象中的属性名称 javaType 属性:被包含对象的数据类型 many 属性:一对多查询固定属性 |
@Many | 一对多查询的注解。 select 属性:指定调用某个接口中的方法 |
来源:https://yangyongli.blog.csdn.net/article/details/125591448
标签:MyBatis,多对多查询,注解开发
0
投稿
猜你喜欢
JavaWeb开发基于ssm的校园服务系统(实例详解)
2022-11-07 16:40:48
Java 使用 HttpClient 发送 GET请求和 POST请求
2023-07-23 07:56:13
JAVA中使用FTPClient实现文件上传下载实例代码
2021-08-17 20:45:05
C# 遍历枚举类型的所有元素
2023-02-06 00:27:46
c# Linq distinct不会调用Equals方法详解
2021-09-03 09:53:13
详解使用SSM实现简单工作流系统之实现篇
2021-10-21 07:49:23
java AOP原理以及实例用法总结
2022-11-05 03:30:41
详解JAVA里面获取map的key和value的方法
2023-04-27 03:11:50
mybatis日志打印的两款IDEA插件推荐
2022-01-12 07:55:52
Android zygote启动流程详解
2023-09-13 07:44:12
Java中实现可拖放图片剪裁入门教程
2022-04-23 12:11:03
解决RestTemplate加@Autowired注入不了的问题
2022-07-14 03:00:48
SpringBoot详细讲解视图整合引擎thymeleaf
2023-12-04 16:31:37
Spring集成jedis的配置与使用简单实例
2023-07-02 04:11:39
Java中基于Shiro,JWT实现微信小程序登录完整例子及实现过程
2023-07-05 15:01:42
Android 文件存储系统原理
2021-12-24 05:10:57
Android微信Tinker热更新详细使用
2021-08-24 01:58:47
C#实现文件压缩与解压的方法示例【ZIP格式】
2021-12-31 23:25:20
Android编程中File文件常见存储与读取操作demo示例
2021-11-24 18:33:20
SpringBoot详解如何进行整合Druid数据源
2022-05-10 10:46:54