目录
Mybatis
MyBatis 框架简介
Mybatis 的前身是 Apache 的开源框架 iBatis,与 Hibernate 一样是一个 Java 持久层的框
架。Mybatis 的优势在于灵活,它几乎可以替代 JDBC,同时提供了接口编程。目前 Mybatis
的数据访问层 DAO(Data Access Object)是不需要实现类的,它只需要一个接口和 XML(或
者注解)。Mybatis 提供自动映射,动态 SQL,级联,缓存,注解,代码和 SQL 分离等特性,
使用方便,同时也对 SQL 进行优化。因为其具有封装少,映射多样化,支持存储过程,可
以进行 SQL 优化等特点,使得它取代了 Hibernate 成为 Java 互联网中首选持久层框架。
Mybatis 在完成其功能的过程中,主要完成两件事情:
1)封装 JDBC 操作;
2)利用反射打通 Java 类和 sql 语句之间的关系。
Mybatis 框架的建立是为了解决传统 JDBC 连接数据库中存在的大量编码问题。Mybatis
可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 中的普通对象映射成数
据库中的记录
Mybatis 框架执行流程图
SqlSession 去执行操作查询数据库映射文件,用途:
1)获取映射器,让映射器通过命名空间和方法名称找到对应的 SQL,发送给数据库,执
行后返回结果。
2)直接通过命名信息去执行 SQL 返回结果。
映射器
MyBatis 框架包括两种类型的 XML 文件,一类是配置文件,即 mybatis-config.xml,另外
一类是映射文件,例如 XXXMapper.xml 等。在 MyBatis 的配置文件 mybatis-config.xml 包含了
节点,这里就是 MyBatis 映射器。
- MyBatis 映射器分为三类,如下所示:
(1)纯 XML 映射器,利用 SqlSession 的各种方法实现增删改查。例如:
Person p = session.selectOne("cn.mybatis.mydemo.mapper.PersonMapper.selectPersonById", 1);
(2)XML 映射器+接口映射器的混合类型
先定义接口映射器,然后再定义 xml 映射器,其中 xml 映射器的 namespace 应该对应接
口映射器的类名。
(3)注解+接口映射器的混合形式
此类形式,将原先 xml 里面的 sql 配置信息,变成 Java 注解的形式写到接口映射器,用
法与上面的例子雷同。 - XML 映射器+接口映射器的混合类型
映射器由 Java 接口和 XML 文件(或注解)共同组成,它的作用:
定义参数类型
描述缓冲描述
SQL 语句定义
查询结果和 POJO 的映射关系
实例:先定义一个映射器接口,如下所示
java
public interface StudentMapper {
public Student getStudent(Long id);
}
注意:映射器只是一个接口,而不是一个实现类。初学者可能会产生一个很大的疑问:
接口不是不能运行吗?的确,接口不能直接运行,但是 MyBatis 内部运用了动态代理技术,
生成接口的实现类,从而完成接口的相关功能。只要明白 MyBatis 会为这个接口生成一个
代理对象,代理对象会去处理映射器接口相关的逻辑即可。
然后,用 XML 方式创建映射器,如下所示:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cn.mybatis.mydemo.mapper.StudentMapper">
<select id="getStudent" parameterType="long" resultType="student">
SELECT id,name,address FROM Student WHERE id =#{id}
</select>
</mapper>
有了这两个文件,就完成了一个映射器的定义。关于 XML 文件内容介绍,如下所示:
(1) 元素中的属性 namespace 所对应的是一个接口的全限定名,于是
MyBatis 上下文就可以通过它找到对应的接口。
3
(2) 元素表明这是一条查询语句,而属性 id 标识了这条 SQL,属性
parameterType="long" 说明传递给 SQL 的是一个 long 型的参数,而 resultType="student"
表示返回的是一个 Student 类型的返回值。而 student 是配置文件 mybatis-config.xml 配置
的别名,指代的是 com.mybatis.domain.Student。这条 SQL 中的 #{id} 表示传递进去的参数
实验目的
(1) 掌握 Mybatis 框架的基本构成
(2) 掌握如何在 Spring Boot 中集成 Mybatis 框架
(3) 掌握 Mybatis 框架实现查询等操作方法
实验内容
Spring Boot 集成 Mybatis 框架实现用户信息的增删改查操作
实验过程
数据库准备
在mysql中准备一个有username并且内容不是中文的表
实例如下
sql
CREATE TABLE `t_user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`user_name` varchar(32) NOT NULL COMMENT '用户名称',
`note` varchar(256) DEFAULT NULL COMMENT '备注',
PRIMARY KEY (`id`)
)
录入数据
项目结构
代码实现
IUserDao
java
import java.util.List;
/**
* @author hongjun
* @create 2020-10-28 17:27
*/
public interface IUserDao {
/*
* 查询所有用户信息
* */
List<User> findAll();
}
IUserDaoImpl
java
import com.example.mybatis1.domain.User;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import java.util.List;
/**
* @author hongjun
* @create 2020-11-01 9:49
*/
public class IUserDaoImpl implements IUserDao{
private SqlSessionFactory sqlSessionFactory;
public IUserDaoImpl(SqlSessionFactory sqlSessionFactory){
this.sqlSessionFactory=sqlSessionFactory;
}
@Override
public List<User> findAll() {
SqlSession sqlSession= sqlSessionFactory.openSession();
List<User> userList=sqlSession.selectList("com.example.mybatis1.dao.IUserDao.findAll");
sqlSession.close();
return userList;
}
}
User
java
import lombok.Data;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
/**
* @author hongjun
* @create 2020-08-24 15:28
* id bigint not null,
* dept_id bigint,
* username varchar(20),
* password varchar(50),
* realname varchar(10),
* sex varchar(10),
* telephone varchar(30),
* email varchar(200),
* avatar varchar(300),
* job_title varchar(30),
* status tinyint,
* sort int,
* del_flag int comment '0 未删除 1 已删除',
* create_time datetime,
* create_by varchar(20),
* update_time datetime,
*/
@Data
public class User {
private Integer id;
private Integer dept_id;
private String username;
private String password;
private String realname;
private String sex;
private String telephone;
private String email;
private String avastar;
private String jobTitle;
private Integer status;
private Integer sort;
private Integer delFlag;
private Date createTime;
private Date updateTime;
private String createBy;
}
IUserDao.xml
java
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.mybatis1.dao.IUserDao">
<select id="findAll" resultType="com.example.mybatis1.domain.User">
select * from user
</select>
</mapper>
SqlMapConfig.xml
java
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!--配置环境-->
<environments default="mysql">
<!--配置mysql环境-->
<environment id="mysql">
<!--配置事务-->
<transactionManager type="JDBC"></transactionManager>
<!--配置连接池-->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.cj.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/stu?serverTimezone=Asia/Shanghai"/>
<property name="username" value="root"/>
<property name="password" value="password"/>
</dataSource>
</environment>
</environments>
<!--配置映射文件的位置-->
<mappers>
<!--配置文件方式,每一个映射文件所在的地方-->
<mapper resource="com/example/mybatis1/dao/IUserDao.xml"></mapper>
<!--注解方式-->
<!-- <mapper class="nuc.edu.mybatis.dao.IUserDao"></mapper>-->
</mappers>
</configuration>
实验结果
如图所示,已经查询了出来