快速入门
开发步骤
1.导入MyBatis的坐标和其他相关坐标
1 | <properties> |
2.创建user数据表
| 名 | 类型 | 长度 | 小数点 | 允许空值 | 键 |
| ——– | ——- | — | —— | ——- | – |
| id | int | 11 | 0 | 允许 | 1 |
| username | varchar | 50 | 0 | 不允许 | |
| password | varchar | 50 | 0 | 不允许 | |
3.编写User实体
1 | public class User { |
4.编写UserMapper映射文件
1 |
|
5.编写MyBatis核心文件
1 |
|
6.编写测试代码
1 | //加载核心配置文件 |
MyBatis的增删改查操作
MyBatis的插入数据操作
1.编写UserMapper映射文件
1 | <mapper namespace="userMapper"> |
2.编写插入实体User的代码
1 | InputStream resourceAsStream = |
3.插入操作注意问题
- 插入语句使用insert标签
- 在映射文件中使用parameterType属性指定要插入的数据类型
- sql语句中使用#{实体属性名}方式引用实体类中的属性值
- 插入操作使用的API是sqlSession.insert(“命名空间.id”,实体对象);
- 插入操作涉及数据库数据变化,所以要使用sqlSession对象显示的提交事务,及sqlSession.commot()
MyBatis的修改数据操作
1.编写UserMapper映射文件
1 | <mapper namespace="userMapper"> |
2.编写修改实体User的代码
1 | InputStream resourceAsStream = Resources.getResourceAsStream("SqlMapConfig.xml"); |
3.修改操作注意问题
1.编写UserMapper映射文件
1 | <mapper namespace="userMapper"> |
2.编写删除数据的代码
1 | InputStream resourceAsStream = Resources.getResourceAsStream("SqlMapConfig.xml"); |
3.删除操作注意问题
- 删除语句使用delete标签
- Sql语句中使用#{任意字符串}方式引用传递的单个参数
- 删除操作使用的API是sqlSession.delete(“命名空间.id”,Object);
MyBatis的映射文件概述
入门核心配置文件分析
MyBatis核心配置文件层级关系
- configuration 配置
1.environments标签
数据库环境的配置,支持多环境配置
其中,事务管理器(transactionManager)类型有两种:
- JDBC:这个配置就是直接使用了JDBC的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作用域。
- MANAGED:这个配置几乎没做什么。他从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期(比如JEE应用服务器的上下文)。默认情况下他会关闭连接,然而一些容器并不希望这样,因此需要将closeConnection属性设置为false来阻止它默认的关闭行为。
其中,数据源(dataSource)类型有三种: - UNPOOLED:这个数据源的实现只是每次被请求时打开和关闭连接。
- POOLED:这个数据源的实现利用”池”的概念将JDBC 连接对象组织起来。
- JNDL:这个数据源的实现是为了能在如EJB或应用服务器这类容器中使用,容器可以集中或在外部配置数据源,然后放置一个JNDL上下文的引用。
2.mapper标签
该标签的作用是加载映射的,加载方式有如下几种:
- 使用相对于类路径的资源引用,例如:
<mapper resource="org/mybatis/builder/AuthorMapper.xml"/>
- 使用完全限定资源定位符(URL),例如:
<mapper url="file:///var/mappers/AuthorMapper.xml"/>
- 使用映射器接口实现类的完全限定类名,例如:
<mapper class="org.mybatis.builder.AuthorMapper"/>
- 将包内的映射器接口实现全部注册为映射器,例如:
<package name="org.mybatis.builder"/>
Mybatis相应API介绍
SqlSession工厂构建器SqlSessionFactoryBuilder
常用API:SqlSessionFactory build(InputStream inputStream)
通过加载mybatis的核心文件的输入流的形式构建一个SqlSessionFactory对象
1 | String resource = "org/mybatis/builder/mybatis-config.xml"; |
其中,Resources工具类,这个类在 org.apache.ibatis.io包中。Resources类帮助你从类路径下、文
件系统或一个web URL中加载资源文件。
SqlSession工厂对象SqlSessionFactory
SqlSessionFactory 有多个个方法创建SqlSession 实例。常用的有如下两个:
SqlSession会话对象
SqlSession 实例在 MyBatis 中是非常强大的一个类。在这里你会看到所有执行语句、提交或回滚事务和
获取映射器实例的方法。
执行语句的方法主要有:
1 | <T> T selectOne(String statement, Object parameter) |
操作事务的方法主要有:
1 | void commit() |
Mybatis的Dao层实现
传统开发方式
编写UserDao接口
1 | public interface UserDao { |
编写UserDaoImpl实现
1 | public class UserDaoImpl implements UserDao { |
测试传统方式
1 |
|
代理开发方式
代理开发方式介绍
采用 Mybatis 的代理开发方式实现 DAO 层的开发,这种方式是我们后面进入企业的主流。
Mapper 接口开发方法只需要程序员编写Mapper 接口(相当于Dao 接口),由Mybatis 框架根据接口定义创建接口的动态代理对象,代理对象的方法体同上边Dao接口实现类方法。
Mapper 接口开发需要遵循以下规范:
- Mapper.xml文件中的namespace与mapper接口的全限定名相同
- Mapper接口方法名和Mapper.xml中定义的每个statement的id相同
- Mapper接口方法的输入参数类型和mapper.xml中定义的每个sql的parameterType的类型相同
- Mapper接口方法的输出参数类型和mapper.xml中定义的每个sql的resultType的类型相同
编写UserMapper接口
测试代理方式1
2
3
4
5
6
7
8
9
10
11
public void testProxyDao() throws IOException {
InputStream resourceAsStream = Resources.getResourceAsStream("SqlMapConfig.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
SqlSession sqlSession = sqlSessionFactory.openSession();
//获得MyBatis框架生成的UserMapper接口的实现类
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
User user = userMapper.findById(1);
System.out.println(user);
sqlSession.close();
}