Mybatis配置之别名(typeAliases)优化、设置(settings)优化、映射器(mappers)优化以及生命周期和作用域的学习和理解

一.Mybatis配置之别名优化

发现Mybatis在类配置文件中,执行Sql语句时如下,非常繁琐

resultType="com.zhu.pojo.User"

发现官方文档给出了解决方案:

image-20230328123855987

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)优化

image-20230328124846077

开启缓存和懒加载

image-20230328124857829

三.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>

四. 生命周期和作用域

作用域和生命周期类别是至关重要的,因为错误的使用会导致非常严重的并发问题。

image-20230328151849436

1.SqlSessionFactoryBuilder

  • 一旦创建了 SqlSessionFactory,就不再需要它了。

2.SqlSessionFactory

  • 作用类似于数据库连接池。

  • 一旦被创建就应该在应用的运行期间一直存在,没有任何理由丢弃它或重新创建另一个实例。

  • SqlSessionFactoryBuilder 实例的最佳作用域是方法作用域(也就是局部方法变量)

3.SqlSession

  • 连接到连接池的一个请求。
  • 每个线程都应该有它自己的 SqlSession 实例。
  • SqlSession 的实例不是线程安全的,因此是不能被共享的,所以它的最佳的作用域是请求或方法作用域。
  • 用完之后需要立即关闭,否则会造成资源浪费。

image-20230328152519724

上面图片里的每一个Mapper就是一个业务。

猜你喜欢

转载自blog.csdn.net/weixin_52908342/article/details/129817317