Mybatis(2)

Mybatis

1.配置解析

在这里插入图片描述

2.环境配置

在这里插入图片描述

如官网所说:**尽管可以配置多个环境,但每个 SqlSessionFactory 实例只能选择一种环境。
**
在这里插入图片描述

事务管理器(transactionManager

在Mabatis中 有两种类型的事务管理器: JDBC 、MANAGED

一般默认使用JDBC

数据源(dataSource)

dataSource 元素使用标准的 JDBC 数据源接口来配置 JDBC 连接对象的资源。

三种

UNPOOLED :无连接池的

POOLED–:这种数据源的实现利用“池”的概念将 JDBC 连接对象组织起来,避免了创建新的连接实例时所必需的初始化和认证时间。 这种处理方式很流行,能使并发 Web 应用快速响应请求

JNDI – 这个数据源实现是为了能在如 EJB 或应用服务器这类容器中使用,容器可以集中或在外部配置数据源,然后放置一个 JNDI 上下文的数据源引用

默认使用POOLED 数据源

3.属性(properties)

我们可以通过properties属性来实现引用配置文件

这些属性可以在外部进行配置,并可以进行动态替换。你既可以在典型的 Java 属性文件中配置这些属性,也可以在 properties 元素的子元素中设置

新建一个db.properties文件
在这里插入图片描述

在XML配置文件中引入它
在这里插入图片描述

注意

优先级问题:优先使用外联文件定义的属性
在这里插入图片描述

这里会优先使用 username=root这个属性!

4.类型别名(typeAliases)

给实体类重命名

类型别名可为 Java 类型设置一个缩写名字。 它仅用于 XML 配置,意在降低冗余的全限定类名书写。 可以给你的实体类 设置一个缩写名字,方便使用。

方式一:修改具体类的名字
<typeAliases>
    <typeAlias  alias="User"  type="com.lei.pojo.User"></typeAlias>
</typeAliases>
方式二:指定一个包名,MyBatis 会在包名下面搜索需要的 Java Bean
每一个在包 domain.blog 中的 Java Bean,在没有注解的情况下,会使用 Bean 的首字母小写的非限定类名来作为它的别名。 比如 domain.blog.Author 的别名为 author
<package name="com.lei.pojo.User" ></package>
则他的别名为user

5.设置(settings)

这是 MyBatis 中极为重要的调整设置,它们会改变 MyBatis 的运行时行为。 下表描述了设置中各项设置的含义、默认值等。

开启缓存和懒加载

在这里插入图片描述

驼峰命名

在这里插入图片描述

打印日志
在这里插入图片描述

6.映射器(mappers)

在这里插入图片描述

上面三个了解即可

用来注册绑定我们的Mapper文件

方式一: 使用xml文件注册

<mappers>
    <mapper resource="com/lei/dao/UserMapper.xml"/>
</mappers>

方式二: 使用Class文件绑定注册

<!-- 使用映射器接口实现类的完全限定类名 -->
<mappers>
  <mapper class="org.mybatis.builder.AuthorMapper"/>
  <mapper class="org.mybatis.builder.BlogMapper"/>
  <mapper class="org.mybatis.builder.PostMapper"/>
</mappers>
注意:接口必须和xml文件同名且在同一包下

方式三:使用包扫描注册

<!-- 将包内的映射器接口实现全部注册为映射器 -->
<mappers>
  <package name="org.mybatis.builder"/>
</mappers>
注意:接口必须和xml文件同名且在同一包下

7.生命周期和作用域

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

流程:
在这里插入图片描述

SqlSessionFactoryBuilder

一旦创建了 SqlSessionFactory,就不再需要它了。 因此 SqlSessionFactoryBuilder 实例的最佳作用域是方法作用域(也就是局部方法变量)。

SqlSessionFactory
  • 可以把它想象成数据库连接池
  • SqlSessionFactory 一旦被创建就应该在应用的运行期间一直存在,没有任何理由丢弃它或重新创建另一个实例。
  • 因此 SqlSessionFactory 的最佳作用域是应用作用域。 有很多方法可以做到,最简单的就是使用单例模式或者静态单例模式。
SqlSession
  • 连接到连接池的一个请求

  • 每个线程都应该有它自己的 SqlSession 实例。SqlSession 的实例不是线程安全的,因此是不能被共享的,所以它的最佳的作用域是请求或方法作用域。

  • 用完之后需要赶紧关闭,否则资源会被占用!

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HsfjryDc-1595169339794)(assets/1595071066881.png)]

每一个Mapper都代表一个具体的业务。

8.ResultMap

结果集映射

<!--结果集映射-->
<resultMap id="UserMap" type="User">
    <!--column数据库中的字段 映射为 实体类中的属性  -->
    <result column="pwd" property="password"></result>
</resultMap>

作用:解决属性名和字段名不一致的问题

当实体类的属性名和数据库表字段名不一致时 你查出来的属性会显示为null
在这里插入图片描述

解决方法:在XML文件中设置结果集映射
在这里插入图片描述

  • resultMap 元素是 MyBatis 中最重要最强大的元素
    9339802)]

[外链图片转存中…(img-NsUPzjne-1595169339805)]

  • resultMap 元素是 MyBatis 中最重要最强大的元素
  • ResultMap 的设计思想是,对简单的语句做到零配置,对于复杂一点的语句,只需要描述语句之间的关系就行了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值