一、介绍
1.1简介
- 是一个基于Java的持久层框架。 iBatis提供的持久层框架包括SQL Maps和Data Access Objects(DAO)
1.2、Mybatis特性
- MyBatis支持定制化SQL、存储过程以及高级映射
- MyBatis避免了几乎所有的JDBC代码和手动设置参数以及结果集解析操作
- MyBatis可以使用简单的XML或注解实现配置和原始映射;将接口和Java的POJO(Plain Ordinary Java Object,普通的Java对象)映射成数据库中的记录
- Mybatis是一个半自动的ORM(Object Relation Mapping:关系和对象映射)框架
二、配置环境
2.1、导入相关Maven资源
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.9</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.29</version>
</dependency>
2.2、设置相关pojo类
和JavaWeb步骤一致
2.3、创建接口
Mapper接口相当于之前的Dao层。但是Mapper只提供接口,不用写实现类
package mapper;
public interface StudentMapper {
public int InsertStudent();
}
2.4、准备配置文件
[1]Mybatis 全局配置文件
习惯上命名为 mybatis-config.xml,这个文件名仅仅只是建议,并非强制要求。将来整合 Spring 之后,这个配置文件可以省略,所以大家操作时可以直接复制、粘贴。
<?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表示配置Mybatis的开发环境,可以配置多个环境,在众多具体环境中,使用default属性指定实际运行时使用的环境。default属性的取值是environment标签的id属性的值。 -->
<environments default="development">
<!-- environment表示配置Mybatis的一个具体的连接数据库的环境 -->
<environment id="development">
<!-- Mybatis的内置的事务管理器:JDBC|MANAGED -->
<transactionManager type="JDBC"/>
<!-- 配置数据源 :POOLED -->
<dataSource type="POOLED">
<!-- 建立数据库连接的具体信息 -->
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/mybatis-example"/>
<property name="username" value="root"/>
<property name="password" value="atguigu"/>
</dataSource>
</environment>
</environments>
<mappers>
<!-- Mapper注册:指定Mybatis映射文件的具体位置 -->
<!-- mapper标签:配置一个具体的Mapper映射文件 -->
<!-- resource属性:指定Mapper映射文件的实际存储位置,这里需要使用一个以类路径根目录为基准的相对路径 -->
<!-- 对Maven工程的目录结构来说,resources目录下的内容会直接放入类路径,所以这里我们可以以resources目录为基准 -->
<mapper resource="mappers/EmployeeMapper.xml"/>
</mappers>
</configuration>
注意:配置文件存放的位置是src/main/resources目录下
[2]Mybatis 映射文件
相关概念:ORM(Object Relationship Mapping)对象关系映射。
- 对象:Java的实体类对象
- 关系:关系型数据库
- 映射:二者之间的对应关系
下表列举的是最简单的单表映射(一个表和一个类):
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属性:在Mybatis全局范围内找到一个具体的Mapper配置 -->
<!-- 引入接口后,为了方便通过接口全类名来找到Mapper配置文件,所以通常将namespace属性设置为接口全类名 -->
<mapper namespace="com.atguigu.mybatis.dao.EmployeeMapper">
<!-- 编写具体的SQL语句,使用id属性唯一的标记一条SQL语句 -->
<!-- resultType属性:指定封装查询结果的Java实体类的全类名 -->
<select id="selectEmployee" resultType="com.atguigu.mybatis.entity.Employee">
<!-- Mybatis负责把SQL语句中的#{}部分替换成“?”占位符,在#{}内部还是要声明一个见名知意的名称 -->
select emp_id empId,emp_name empName,emp_salary empSalary from t_emp where emp_id=#{empId}
</select>
</mapper>
注意:
-
EmployeeMapper.xml所在的目录要和mybatis-config.xml中使用mapper标签配置的一致
-
接口名称和映射文件 namespace保持一致
- 接口中的**方法名和映射文件中sql的 id **保持一致
- 创建完后 去mybatis的配置文件中修改Mappers
2.5、测试
public class MyBatisTest {
@Test
public void Test01() throws IOException {
//获取核心配置文件的输入流
InputStream resource = Resources.getResourceAsStream("mybatis-config.xml");
//获取SqlSessionFactoryBuilder对象
SqlSessionFactoryBuilder sqlSessionFactoryBuilder=new SqlSessionFactoryBuilder();
//获取SqlSessionFactory对象(工厂设计模式)
SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(resource);
//获取sqlSession对象,是Mybatis负责操作数据库的对象
SqlSession sqlSession = sqlSessionFactory.openSession();
//获取Mapper接口的代理实现对象(代理模式)
StudentMapper studentMapper = sqlSession.getMapper(StudentMapper.class);
//调用studentMapper功能进行测试
int i = studentMapper.InsertStudent();
sqlSession.commit();//提交事务
System.out.println("影响的行数是:"+i);//影响的行数是:1
sqlSession.close();
}
}