MyBatis

MyBatis功能架构设计在这里插入图片描述

MyBatis框架架构设计

加载配置:
配置来源于两个地方,一处是配置文件,一处是Java代码的注解,
将SQL的配置信息加载成为一个个MappedStatement对象
(包括了传入参数映射配置、执行的SQL语句、结果映射配置),
存储在内存中。
SQL解析:
当API接口层接收到调用请求时,会接收到传入SQL的ID和传入对象
(可以是Map、JavaBean或者基本数据类型),
Mybatis会根据SQL的ID找到对应的MappedStatement,
然后根据传入参数对象对MappedStatement进行解析,
解析后可以得到最终要执行的SQL语句和参数。
SQL执行:
将最终得到的SQL和参数拿到数据库进行执行,得到操作数据库的结果。
结果映射:
将操作数据库的结果按照映射的配置进行转换,
可以转换成HashMap、JavaBean或者基本数据类型,
并将最终结果返回。

在这里插入图片描述
在这里插入图片描述
总体来说 MyBatis 主要完成两件事情:
1、根据 JDBC 规范建立与数据库的连接;
2、通过Annotaion/XML+JAVA反射技术,实现 Java 对象与关系数据库之间相互转化。

MyBatis 核心XML配置文件

MyBatis 的 XML 配置文件包含了影响 MyBatis 行为的设置和属性信息。
XML 文档的高层级结构如下:
configuration 配置
properties 属性
settings 设置
typeAliases 类型命名
typeHandlers 类型处理器
objectFactory 对象工厂
plugins 插件
environments 环境
——environment 环境变量
——transactionManager 事务管理器
——dataSource 数据源
mappers 映射器

environments 环境

MyBatis 可以配置多种环境——>SQL 映射应用于多种数据库之中**
注意:**可以配置多种环境,但只能为每个 SqlSessionFactory 实例选择一个环境。也就是说每个数据库对应一个 SqlSessionFactory。

dataSource 数据源

有三种内建的数据源类型
type=
UNPOOLED
POOLED
JNDI

mappers 映射器

既然 MyBatis 的行为已经由上述元素配置完了,我们现在就要定义 SQL 映射语句了。
但是, 首先我们需要告诉 MyBatis 到哪里去找到这些语句:
在这里插入图片描述

MyBatis Mapper XML 文件

MyBatis 真正的力量是在映射语句中,SQL 映射的 XML 文件是相当的简单。
当然如果你将它们和对等功能的 JDBC
代码来比较,你会发现映射文件节省了大量的代码量。

cache - 配置给定命名空间的缓存
cache-ref – 从其他命名空间引用缓存配置
resultMap – 最复杂,也是最有力量的元素,用来描述如何从数据库结果集中来加载你的对象
sql – 可以重用的 SQL 块,也可以被其他语句引用
insert – 映射插入语句
update – 映射更新语句
delete – 映射删除语句
select – 映射查询语句

select

在这里插入图片描述

insert

在这里插入图片描述

delete

在这里插入图片描述

update

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值