后端框架的学习----mybatis框架(3、配置解析)

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 的实例不是线程安全的,因此是不能被共享的,所以它的最佳的作用域是请求或方法作用域
  • 连接之后要赶紧关闭,否则资源被占用
posted on 2022-08-28 22:19  热爱技术的小郑  阅读(22)  评论(0编辑  收藏  举报