mybatis学习 04

一.MyBatis 实现多表查询

1.Mybatis 实现多表查询方式

1.1 业务装配.对两个表编写单表查询语句,在业务(Service)把查询

的两个结果进行关联.

1.2 使用 Auto Mapping 特性,在实现两表联合查询时通过别名完成

映射.

1.3 使用 MyBatis 的标签进行实现.

2.多表查询时,类中包含另一个类的对象的分类

2.1 单个对象

2.2 集合对象.

二.resultMap 标签

1.标签写在 mapper.xml 中,由程序员控制 SQL 查询结果与实体类的映射关系.

1.1 默认 MyBatis 使用 Auto Mapping 特性.

2.使用标签时,标签不写 resultType 属性,而是使用 resultMap 属性引用标签.

3.使用 resultMap 实现单表映射关系

3.1 数据库设计

3.2 实体类设计

3.3 mapper.xml 代码

select * from teacher

  1. 使用 resultMap 实现关联单个对象(N+1 方式)

4.1 N+1 查询方式,先查询出某个表的全部信息,根据这个表的信息

查询另一个表的信息.

4.2 与业务装配的区别:

4.3.1 在 service 里面写的代码,由 mybatis 完成装配

4.3 实现步骤:

4.3.1 在 Student 实现类中包含了一个 Teacher 对象

public class Student {

private int id;

private String name;

private int age;

private int tid;

private Teacher teacher;

4.3.2 在 TeacherMapper 中提供一个查询

<select id=“selById” resultType=“teacher”

parameterType=“int”>

select * from teacher where id=#{0}

4.3.3 在 StudentMapper 中

4.3.3.1 装配一个对象时使用

4.3.3.2 property: 对象在类中的属性名

4.3.3.3 select:通过哪个查询查询出这个对象的信息

4.3.3.4 column: 把当前表的哪个列的值做为参数传递给另

一个查询

4.3.3.5 大前提使用 N+1 方式.时如果列名和属性名相同可以不配置,使用 Auto mapping 特性.但是 mybatis 默认只会给列

专配一次

<association property=“teacher”

select=“com.bjsxt.mapper.TeacherMapper.selById”

column=“tid”>

select * from student

4.3.3.6 把上面代码简化成

<association property=“teacher”

select=“com.bjsxt.mapper.TeacherMapper.selById” column=“tid”>

select * from student

5.使用 resultMap 实现关联单个对象(联合查询方式)

5.1 只需要编写一个 SQL,在 StudentMapper 中添加下面效果

5.1.1 只要专配一个对象就用这个标签

5.1.2 此时把小的看待

5.1.3 javaType 属性:专配完后返回一个什么类型

的对象.取值是一个类(或类的别名)

<association property=“teacher”

javaType=“Teacher” >

select s.id sid,s.name sname,age age,t.id

tid,t.name tname FROM student s left outer join teacher t on s.tid=t.id

6.N+1 方式和联合查询方式对比

6.1 N+1:需求不确定时.

6.2 联合查询:需求中确定查询时两个表一定都查询.

7.N+1 名称由来

7.1 举例:学生中有 3 条数据

7.2 需求:查询所有学生信息级授课老师信息

7.3 需要执行的 SQL 命令

7.3.1 查询全部学生信息:select * from 学生

7.3.2 执行 3 遍 select * from 老师 where id=学生的外键

7.4 使用多条 SQl 命令查询两表数据时,如果希望把需要的数据都

查询出来,需要执行 N+1 条 SQl 才能把所有数据库查询出来.

7.5 缺点:

7.5.1 效率低

7.6 优点:

7.6.1 如果有的时候不需要查询学生是同时查询老师.只需要

执行一个 select * from student;

7.7 适用场景: 有的时候需要查询学生同时查询老师,有的时候只

需要查询学生.

7.8 如果解决 N+1 查询带来的效率低的问题

7.8.1 默认带的前提: 每次都是两个都查询.

7.8.2 使用两表联合查询.

三.使用查询关联集合对象(N+1)

  1. 在 Teacher 中添加 List

public class Teacher {

private int id;

private String name;

private List list;

  1. 在 StudentMapper.xml 中添加通过 tid 查询

<select id=“selByTid” parameterType=“int”

resultType=“student”>

select * from student where tid=#{0}

  1. 在 TeacherMapper.xml 中添加查询全部

3.1 当属性是集合类型时使用的标签.

<collection property=“list”

select=“com.bjsxt.mapper.StudentMapper.selByTid”

column=“id”>

select * from teacher

四.使用实现加载集合数据(联合查询方式)

1.在 teacherMapper.xml 中添加

1.1 mybatis 可以通过主键判断对象是否被加载过.

1.2 不需要担心创建重复 Teacher

select t.id tid,t.name tname,s.id sid,s.name

sname,age,tid from teacher t LEFT JOIN student s on t.id=s.tid;

五.使用 Auto Mapping 结合别名实现多表查询.

5.1 只能使用多表联合查询方式.

5.2 要求:查询出的列别和属性名相同.

5.3 实现方式

5.3.1 .在 SQL 是关键字符,两侧添加反单引号

select t.id teacher.id,t.name

teacher.name,s.id id,s.name name,age,tid

from student s LEFT JOIN teacher t on t.id=s.tid

六.MyBatis 注解

1.注解:为了简化配置文件.

2.Mybatis 的注解简化 mapper.xml 文件.

2.1 如果涉及动态 SQL 依然使用 mapper.xml

3.mapper.xml 和注解可以共存.

4.使用注解时 mybatis.xml 中使用 4.1

4.2

5.实现查询

@Select(“select * from teacher”)

List selAll();

6.实现新增

@Insert(“insert into teacher values(default,#{name})”)

int insTeacher(Teacher teacher);

7.实现修改

@Update(“update teacher set name=#{name} where id=#{id}”)

int updTeacher(Teacher teacher);

8.实现删除

@Delete(“delete from teacher where id=#{0}”)

int delById(int id);

9.使用注解实现功能 9.1 以 N+1 举例

9.2 在 StudentMapper 接口添加查询

@Select(“select * from student where tid=#{0}”) List selByTid(int tid);

9.3 在 TeacherMapper 接口添加

9.3.1 @Results() 相当于

9.3.2 @Result() 相当于或

9.3.2.1 @Result(id=true) 相当与

9.3.3 @Many() 相当于

9.3.4 @One() 相当于

@Results(value={ @Result(id=true,property=“id”,column=“id”), @Result(property=“name”,column=“name”),

@Result(property=“list”,column=“id”,many=@Many(sele

ct=“com.bjsxt.mapper.StudentMapper.selByTid”))

})

@Select(“select * from teacher”)

List selTeacher();

七. 运行原理

1.运行过程中涉及到的类

1.1 Resources MyBatis 中 IO 流的工具类

1.1 加载配置文件

1.2 SqlSessionFactoryBuilder() 构建器
1.2.1 作用:创建 SqlSessionFactory 接口的实现类
1.3 XMLConfigBuilder MyBatis 全局配置文件内容构建器类
1.3.1 作用负责读取流内容并转换为 JAVA 代码.
1.4 Configuration 封装了全局配置文件所有配置信息.
1.4.1 全局配置文件内容存放在 Configuration 中
1.5 DefaultSqlSessionFactory 是 SqlSessionFactory 接口的实现类
1.6 Transaction 事务类
16.1 每一个 SqlSession 会带有一个 Transaction 对象.
1.7 TransactionFactory 事务工厂
1.7.1 负责生产 Transaction

1.8 Executor MyBatis 执行器

1.8.1 作用:负责执行 SQL 命令

1.8.2 相当于 JDBC 中 statement 对象(或 PreparedStatement

或CallableStatement)

1.8.3 默认的执行器 SimpleExcutor

1.8.4 批量操作 BatchExcutor

1.8.5 通过 openSession(参数控制)

1.9 DefaultSqlSession 是 SqlSession 接口的实现类

1.10 ExceptionFactory MyBatis 中异常工厂

2.流程图

3.文字解释

在MyBatis 运行开始时需要先通过 Resources 加载全局配置文件.下面需要实例化 SqlSessionFactoryBuilder 构建器.帮助 SqlSessionFactory 接口实现类 DefaultSqlSessionFactory.

在实例化 DefaultSqlSessionFactory 之前需要先创建 XmlConfigBuilder 解析全局配置文件流,并把解析结果存放在 Configuration 中.之后把 Configuratin 传递给 DefaultSqlSessionFactory.到此 SqlSessionFactory 工厂创建成功.

由SqlSessionFactory 工厂创建 SqlSession.

每次创建 SqlSession 时,都需要由 TransactionFactory 创建 Transaction 对象 , 同时还需要创建 SqlSession 的执行器 Excutor, 最后实例化DefaultSqlSession,传递给 SqlSession 接口.

根据项目需求使用 SqlSession 接口中的 API 完成具体的事务操作.

如果事务执行失败,需要进行 rollback 回滚事务.

如果事务执行成功提交给数据库.关闭 SqlSession

到此就是 MyBatis 的运行原理.(面试官说的.)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值