Mybatis操作数据库执行流程的先后顺序是怎样的?

数据库 SQL Server
MyBatis是一个支持普通SQL查询、存储及高级映射的持久层框架,它几乎消除了JDBC的冗余代码。使Java开发人员可以使用面向对象的编程思想来操作数据库。对于MyBatis的工作原理和操作流程的理解,我们先来看下面的工作流程图。

MyBatis是一个支持普通SQL查询、存储及高级映射的持久层框架,它几乎消除了JDBC的冗余代码。使Java开发人员可以使用面向对象的编程思想来操作数据库。对于MyBatis的工作原理和操作流程的理解,我们先来看下面的工作流程图。

MaBatis的工作流程

在上图中,MyBatis操作数据库的流程分为8个步骤,具体介绍如下。

(1)MyBatis读取核心配置文件mybatis-config.xml

mybatis-configxml核心配置文件主要配置了MyBatis的运行环境等信息。

(2)加载映射文件Mapperxml

Mapper.xml文件即SQL映射文件,该文件配置了操作数据库的SQL.语句,需要在mybatis-oonfig.xml中加载才能执行。mybatis-configxml 可以加载多个映射文件,每个映射文件对应数据库中的一张表。

(3)构造会话工厂

通过MyBatis的环城h配置信息构建会话工厂SqlSessionFactory,用于创建SqlSession。

(4)创建会话对象

由会话工厂SqlSessionFactory 创建SqlSession对象,该对象中包含了执行SQL.语句的所有方法。

(5)创建执行器

会话对象本身不能直接操作数据库,MyBanis底层定义了一个Executor接口用于操作数据库,执行器会根据SqlSessinn传递的参数动态的生成需要执行的SQL.语句,同时负责查询缓存地维护

(6)封装SQL信息

SqlSession 内部通过执行器Executor 操作数据库,执行器将待处理的SQL.信息封装到MappelStatement对象中,MappedlStatement对象中存储了要映射的SQL.语句的id、参数等。Mappetxml文件中一个SQL语句对应一个MappedStatement 对象,SQL语句的id即是MappedStatement 的id。Eveeator 执行器会在执行SQL语句之前,通过MappelStatement对象将输人的参数映射到SQL.语句中。

(7)操作数据库

根据动态生成的SQL操作数据库。

(8)输出结果映射

执行SQL.语句之后,通过MappedStatement对象将输出结果映射至Java对象中。通过上面对MyBatis框架工作原理的讲解,相信读者对MyBatis框架已经有了一个初步的了解。


责任编辑:华轩 来源: 今日头条
相关推荐

2011-04-19 10:20:09

数据库

2009-09-15 09:50:07

Linq操作数据库

2011-07-01 13:42:24

QT 数据库

2020-11-16 08:56:02

Python

2011-07-05 10:27:06

MySQL数据库检索排序

2023-06-15 15:21:43

2023-04-27 09:36:43

2009-09-03 09:52:26

C# treeview

2009-08-24 16:46:04

C# 泛型

2023-12-27 13:44:00

数据库系统分布式

2010-04-27 10:39:59

Oracle数据库

2023-12-14 15:07:31

多线程数据库代码

2009-07-07 09:24:37

LINQ检索

2016-05-11 10:09:49

数据层代码FastQuery

2009-08-04 14:52:33

Visual Web ASP.NET

2022-10-09 15:41:54

Python数据库

2009-12-28 16:57:40

ADO .NET 类

2024-04-17 08:11:01

数据库事务流程

2021-01-29 10:51:48

高并发数据库缓存

2021-06-29 06:25:22

Nest.jsTypeORM数据库
点赞
收藏

51CTO技术栈公众号