使用mybatis进行多表联查

Posted waibangma

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用mybatis进行多表联查相关的知识,希望对你有一定的参考价值。

一.使用mybatis的基本步骤

1.导入jar包

2.配置文件

3.使用配置文件完成操作

 

二.实战演习

    需求:教师表里有教师id和教师姓名 学生表里有学生id,姓名,年龄,教师id

     一个教师有多个学生,一个学生只有一个教师,现在需要显示学生表的学生信息和教师姓名

1.导入jar包技术图片

2.导入配置文件,mybatis和log4j都是写了一次以后随便用

技术图片技术图片

这些都是写死了的,直接配好即可

三.开始多表联查

1.业务装配方式,分为两步,

1.1查询所有的学生,

1.2根据学生的tid得到教师的信息存入学生类中

技术图片技术图片

得到结果为

技术图片

完成.这是简化版的,直接在test类中显示得到的数据,本来应该写在业务层,传给控制层,在视图层显示

 

2.ResultMapper n+1方式

上面的写法很好理解,但是很繁琐,需要写两遍sql语句

而使用ResultMapper 可以在查询student时跳转至查询teacher语句.一句搞定

技术图片

用到的类有Teacher中的selTeaByTid Student类中的selStuRm.其意义为,查询所有学生,根据注入的属性跳转到根据tid查询所有的教师,association标签表示学生和老师是一对一关系.学生是主语.

如果是根据教师来查学生,就是一对多关系,使用的标签就是collection.意义都是一样的,就是带着值跳转到执行语句

这个方法其实也使用了两句sql语句

还是两次单表查询,访问数据库2次

3.联合查询

其实和上面一样,只是sql语句不再是单表查询了,而是双标联查.ResultMapper也不再是跳转,而是将两个表都拿来做操作

技术图片

 

 在association内再添加联合查询的另一个表.得到相同的结果

回过头来看,ResultMapper n+1方式不如业务装载方式直观,不如联合查询访问次数少,是个中间的存在

在sql语句使用熟练的情况下,还是选联合查询好...

 

以上是关于使用mybatis进行多表联查的主要内容,如果未能解决你的问题,请参考以下文章

MyBatis关于多表联查 关联关系之一--------一对多(单条sql语句查询)

使用mybatis多表联查的时候结果异常及springmvc的理解

MyBatis多表联查

SpringBoot整合mybatis多表联查之数据库建表

什么?mybatis-plus的多表查询,你还在写sql语句?!CRUD2多表联查的三种方式

sql-mybatis-多表查询不查的字段一定不要查