SSM之MyBatis简介、文件配置和API

1. MyBatis简介

mybatis是一个优秀的基于java的持久层框架,它内部封装了jdbc,使开发者只需要关注sql语句本身,而不需要花费精力去处理加载驱动、创建连接、创建statement等繁杂的过程。

mybatisi通过xml或注解的方式将要执行的各种statementi配置起来,并通过java对像和statement中sql的动态参数进行映射生成最终执行的sql语句。

最后mybatis框架执行sql并将结果映射为java对象并返回。采用ORM思想解决了实体和数据库映射的问题,对jdbc进行了封装,屏蔽了jdbc api底层访问细节,使我们不用与jdbc api打交道,就可以完成对数据库的持久化操作。

2. MyBatis开发步骤

  1. 添加MyBatis的坐标
  2. 创建user数据表
  3. 编写User实体类
  4. 编写映射文件UserMapper.xml
  5. 编写核心文件SqlMapConfig.xml
  6. 编写测试类

3. MyBatis的映射文件概述

在这里插入图片描述

4. MyBatis核心配置文件概述

4.1 MyBatis核心配置文件层级关系

configuration配置
properties属性
settings设置
typeAliases类型别名
typeHandlers类型处理器
objectFactory对象工厂
plugins插件
environments环境

  1. environment 环境变量
    1. transactionManager事务管理器
    2. dataSource数据源

databaseIdProvider数据库厂商标识
mappers映射器

4.2 MyBatis常用配置解析

  1. environments标签
    在这里插入图片描述

其中,事务管理器(transactionManager)类型有两种:
JDBC:这个配置就是直接使用了JDBC的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作用域。

MANAGED:这个配置几乎没做什么。它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期(比如JEE应用服务器的上下文)。默认情况下它会关闭连接,然而一些容器并不希望这样,因此需要将closeConnection属性设置为false来阻止它默认的关闭行为。

其中,数据源(dataSource)类型有三种:
·UNPOOLED:这个数据源的实现只是每次被请求时打开和关闭连接。
·POOLED:这种数据源的实现利用“池”的概念将JDBC连接对像组织起来。
·JNDI:这个数据源的实现是为了能在如EJB或应用服务器这类容器中使用,容器可以集中或在外部配置数据源,然后放置一个JNDI上下文的引用。

  1. mapper标签
    该标签的作用是加载映射的,加载方式有如下几种:
    在这里插入图片描述
  2. Properties标签
    实际开发中,习惯将数据源的配置信息单独抽取成一个properties.文件,该标签可以加载额外配置的properties文件。
    在这里插入图片描述

4.3 知识小结

核心配置文件常用配置:

  1. properties标签:该标签可以加载外部的properties文件
<properties resource="jdbc.properties"></properties>
  1. typeAliases标签:设置类型别名
<typeAlias type="com.itheima.domain.User" alias="user"></typeAlias>
  1. mappers标签:加载映射配置
<mapper resource="com/itheima/mapper/UserMapper.xml"></mapper>
  1. environments标签:数据源环境配置标签
    在这里插入图片描述

5. MyBatis相应API

5.1 SqlSession工厂构建器SqlSessionFactoryBuilder

常用API:SqlSessionFactory build(InputStream inputStream)
通过加载mybatis的核心文件的输入流的形式构建一个SqlSessionFactory对象
在这里插入图片描述
其中,Resources工具类,这个类在org.apache.ibatis.io包中。Resources类帮助你从类路径下、文件系统或一个web URL中加载资源文件。

5.2 SqlSession工厂对象SqlSessionFactory

SqlSessionFactory有多个方法创建SqlSession实例。常用的有如下两个:
在这里插入图片描述

5.3 SqlSession会话对象

SqlSession实例在MyBatis中是非常强大的一·个类。在这里你会看到所有执行语句、提交或回滚事务和获取映射器实例的方法。
执行语句的方法主要有:
在这里插入图片描述
操作事务的方法主要有:
在这里插入图片描述
参考资料:Spring+SpringMVC+MyBatis全套教程

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值