3、配置解析
1、核心配置文件
2、环境配置(environment)
3、属性(properties)
可以通过properties属性来实现引用配置文件
这些属性可以在外部进行配置,并可以进行动态替换。你既可以在典型的 Java 属性文件中配置这些属性,也可以在 properties 元素的子元素中设置
编写一个配置文件
driver=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&serverTimezone=Asia/Shanghai
username=用户账号
password=用户密码
在核心配置文件中引入
<!--引入外部配置文件-->
<properties resource="config.properties">
</properties>
另外一种形式
driver=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&serverTimezone=Asia/Shanghai
<!--引入外部配置文件-->
<properties resource="config.properties">
<property name="username" value="root"/>
<property name="password" value="root"/>
</properties>
4、类型别名(typeAliases)
- 类型别名是为java类型设置一个短的名字
- 存在的意义仅在于用来减少类完全限定名的冗余
在核心配置文件中
<!--可以给实体类起别名-->
<typeAliases>
<typeAlias type="com.zheng.pojo.User" alias="User"/>
</typeAliases>
也可以指定一个包名,Mybatis会在包名下面搜索需要的JavaBean:比如:扫描实体类的包,它的默认别名就为这个类的类名,首字母小写
<!--可以给实体类起别名-->
<typeAliases>
<package name="com.zheng.pojo"/>
</typeAliases>
- 实体类比较少的情况下,使用第一种方式
- 实体类多,建议使用第二种
在mapper.xml文件中
<!--查询用户通过id-->
<select id="selectUserById" resultType="User">
select * from mybatis.user where id=#{id}
</select>
5、映射器(mappers)
MapperRegistry:注册绑定我们的Mapper文件:
方式一、
<mappers>
<!--每一个mapper.xml文件都需要在mybatis核心配置文件中被注册-->
<mapper resource="com/zheng/Dao/UserMapper.xml"/>
</mappers>
方式二、使用class绑定注册
<mappers>
<!--每一个mapper.xml文件都需要在mybatis核心配置文件中被注册-->
<mapper class="com.zheng.Dao.UserMapper"/>
</mappers>
注意(使用class和包注意点):
- 接口和它的Mapper配置文件必须同名!
- 接口和它的Mapper配置文件必须在同一个包下
方式三、使用扫描包进行注入绑定
<mappers>
<!--每一个mapper.xml文件都需要在mybatis核心配置文件中被注册-->
<package name="com.zheng.Dao"/>
</mappers>
6、生命周期和作用域
作用域和生命周期类别是至关重要的,因为错误的使用会导致非常严重的并发问题。
1、SqlSessionFactoryBuilder
- 一旦创建了SqlSessionFactory,就不再需要它了
- 局部变量
2、SqlSessionFactory - 说白了可以想象为:数据库连接池
- SqlSessionFactory 一旦被创建就应该在应用的运行期间一直存在,没有任何理由丢弃它或重新创建另一个实例
- SqlSessionFactory 的最佳作用域是应用作用域
- 最简单的就是使用单例模式或者静态单例模式
3、SqlSession - 连接到连接池的一个请求
- SqlSession 的实例不是线程安全的,因此是不能被共享的,所以它的最佳的作用域是请求或方法作用域
- 连接之后要赶紧关闭,否则资源被占用