Mybatis配置之别名(typeAliases)优化、设置(settings)优化、映射器(mappers)优化以及生命周期和作用域的学习和理解
文章目录
- 一.Mybatis配置之别名优化
- 1.1 举例说明
- 1.2 总结
- 二.Mybatis的设置(settings)优化
- 三.Mybatis的映射器(mappers)
- 四. 生命周期和作用域
一.Mybatis配置之别名优化
发现Mybatis在类配置文件中,执行Sql语句时如下,非常繁琐
resultType="com.zhu.pojo.User"
发现官方文档给出了解决方案:
1.1 举例说明
在mybatis-config.xml配置文件中。
别名配置(个实体类起别名):如下写法,可以吧com.zhu.pojo.User起别名为User。
<typeAliases>
<typeAlias alias="User" type="com.zhu.pojo.User"/>
</typeAliases>
在类配置Sql语句可以如下使用:
<select id="getUserList" resultType="User" >
select * from mybatis.user;
</select>
也可以指定一个包名,MyBatis 会在包名下面搜索需要的 Java Bean。
如下:
<typeAliases>
<package name="com.zhu.pojo"/>
</typeAliases>
现在在类配置里,可以写User或者user都可以、
<select id="getUserList" resultType="User" >
select * from mybatis.user;
</select>
1.2 总结
在实体类比较少的时候,使用第一种方式。
如果实体类十分多,建议使用第二种。
第一种可以 DIY 别名,第二种则不行·,如果非要改,需要在实体上增加注解
@Alias("author")
public class Author {
...
}
二.Mybatis的设置(settings)优化
开启缓存和懒加载
三.Mybatis的映射器(mappers)
方式一【推荐使用】:使用相对于类路径的资源引用:
<mappers>
<mapper resource="com/zhu/dao/UserMapper.xml"/>
</mappers>
方式二:使用Class文件绑定注册:
<mappers>
<!-- <mapper resource="com/zhu/dao/UserMapper.xml"/>-->
<mapper class="com.zhu.dao.UserMapper" />
</mappers>
使用Class文件绑定注册的注意点:
- 接口和他的 Mapper 配置文件必须同名!
- 接口和他的 Mapper 配置文件必须在同一个包下!
方式三:使用扫描包进行注入绑定
<mappers>
<!-- <mapper resource="com/zhu/dao/UserMapper.xml"/>-->
<!-- <mapper class="com.zhu.dao.UserMapper" />-->
<package name="com.zhu.dao"/>
</mappers>
四. 生命周期和作用域
作用域和生命周期类别是至关重要的,因为错误的使用会导致非常严重的并发问题。
1.SqlSessionFactoryBuilder
- 一旦创建了 SqlSessionFactory,就不再需要它了。
2.SqlSessionFactory
-
作用类似于数据库连接池。
-
一旦被创建就应该在应用的运行期间一直存在,没有任何理由丢弃它或重新创建另一个实例。
-
SqlSessionFactoryBuilder 实例的最佳作用域是方法作用域(也就是局部方法变量)
3.SqlSession
- 连接到连接池的一个请求。
- 每个线程都应该有它自己的 SqlSession 实例。
- SqlSession 的实例不是线程安全的,因此是不能被共享的,所以它的最佳的作用域是请求或方法作用域。
- 用完之后需要立即关闭,否则会造成资源浪费。
上面图片里的每一个Mapper就是一个业务。