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

news2024/12/30 3:26:57

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

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框架已经有了一个初步的了解。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/544647.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

VMware和Ubuntu20.04的安装

VMware安装: 1、下载好VM后右击管理员运行: PS:推荐大家去官网下载,如果需要许可密钥的话,可以去搜一下,或者私信一下UP,链接放下面了。 VM官网 因为我已经安装好了,所以就不在贴…

Appium自动化环境搭建保姆级教程

APP自动化测试运行环境比较复杂,稍微不注意安装就会失败。我见过不少朋友,装了1个星期,Appium 的运行环境还没有搭好的。 搭建环境本身不是一个有难度的工作,但是 Appium 安装过程中确实存在不少隐藏的比较深的坑,如果…

5.1图的物理结构与基本操作

1.图的物理结构 一.邻接矩阵存储稠密图 用于存储无向图,有向图,总之各类图 优缺点:适合存储稠密图,属于上下三角矩阵,有重复 复杂度:O(V),空间O(V^2) 性质:阶乘得到某一点的值,为顶…

C语言入门级小游戏——三子棋

文章目录 游戏文件的创建游戏菜单重头戏,游戏正式开始棋盘的创建数据清空打印棋盘 玩家下棋电脑下棋输赢的判断1.赢2.平局,游戏继续 代码展示 今天我们写一个小游戏——三子棋来增加我们对编程的兴趣, 希望这篇文章对友友们有帮助! 游戏文件的…

测试进阶-软件测试的分类

目录 按照测试对象划分界面测试 *可靠性测试如何进行可靠性测试 容错性测试文档测试兼容性测试 *易用性测试 *安装卸载测试 *安全测试性能测试内存泄漏测试 按照是否查看代码划分黑盒测试白盒测试灰盒测试 按照开发阶段划分测试金字塔单元测试集成测试系统测试回归测试冒烟测试…

行政前台快递管理软件使用教程

行政前台快递如何管理,是每个行政人员永远避不开的话题。 不管是从行政相关的论坛中,还是从身边从事行政相关工作的亲友口中,亦或是某些公司前台堆积的快递,我们都能看到、听到行政相关人员抱怨“行政前台快递管理为什么这么难”…

办公环境监测与智能控制软硬件全套解决方案

心理学研究表明,良好的工作环境对员工的身心健康及提高工作效率有积极影响。 不仅如此,近几年国家尤其提倡“碳中和”与“碳达峰”政策,并提出“节约能源、美化环境”的重要目标。以“企业数字化转型”为根本,一切事物都在朝着智能…

因子图优化

最大后验概率估计问题 我们常将状态估计问题建模为最大后验估计(MAP)。之所以命名为最大后验估计,是因为它在给定了观测 Z \bm Z Z的情况下,最大化状态 X \bm X X的后验概率密度 p ( X ∣ Z ) p(\bm X|\bm Z) p(X∣Z) X M A P …

迅为RK3568开发板驱动教程更新了兄弟们,思路更科学

驱动视频全新升级,并持续更新~更全,思路更科学,入门更简单。 迅为基于iTOP-RK3568开发板进行讲解,本次更新内容为第九期,主要讲解设备模型,共计29讲。 教程观看链接:B站搜索-迅为电子 课程目录…

Mysql——SUM()函数

目录 一、前期准备工作 新建表如下: 插入的数据如下: 二、SUM()函数的用法 1.求和,返回指定列的总和 SUM 函数可以对单个列求和,也可以对多个列运算后求和,计算中忽略 NULL 值 SUM函数与分组 GROUP BY 使用&a…

MySQL调优系列(五)——索引详解

一、索引的定义 数据库索引就像是书前面的目录,能加快数据库的查询速度。 索引是一种数据结构,用于帮助我们在大量数据中快速定位到我们想要查找的数据。 是一种帮助MySQL高效获取数据的数据结构。 ps:大多数情况下,索引查询都是…

计算机图形学 | 实验九:纹理贴图和天空盒

计算机图形学 | 实验九:纹理贴图和天空盒 计算机图形学 | 实验九:纹理贴图和天空盒实验概述顶点数据立方体顶点数据天空盒顶点数组 纹理载入创建纹理纹理读取纹理绑定 使用纹理立方体着色器顶点着色器片元着色器 天空盒着色器顶点着色器片元着色器 立方体…

管好【SD-WEBUI】中大量的模型:模型信息预览插件(Part.3)

文章目录 (零)前言(一)模型预览图(一)模型信息预览插件(Model Preview)(1.1)示例(Markdown描述提示词备注)(1.2&#xff0…

AI大模型驱动下,数字虚拟人与虚拟场景为高等学院建设带来何种改变?

继今年年初美国人工智能研究实验室OpenAI推出ChatGPT(一种人工智能驱动的自然语言处理工具)之后一段时间里,阿里、百度、商汤等一众国内IT巨头纷纷发布了各自的AI大模型(可浅理解为用于AI学习用的超大量数据)&#xff…

运动控制轴单位设置(H5U PLC)

H5U PLC运动控制相关应用,请参看下面博客文章 10轴总线控制(汇川H5UPLC+总线伺服编程应用)_RXXW_Dor的博客-CSDN博客H5UPLC控制总线伺服的详细配置过程,可以参看下面的文章链接:汇川H5U PLC通过EtherCAT总线控制SV660N和X3E伺服_ethercat总线伺服如何控制_RXXW_Dor的博客-C…

使用MFT进行加密文件传输的7个好处

至少,托管文件传输(MFT)解决方案是一种产品,它包含入站和出站文件传输的所有方面,同时使用行业标准的网络协议和无缝加密。它可以从单个集中管理点在您的网络,系统,应用程序,贸易伙伴…

2024王道数据结构考研丨第二章:线性表

2024王道数据结构考研笔记专栏将持续更新,欢迎 点此 收藏,共同交流学习… 文章目录 第二章:线性表2.1线性表的定义2.2顺序表的定义2.2.1静态分配:2.2.2动态分配 2.2顺序表的基本操作1.插入操作 :平均时间复杂度O(n)2.删除操作&…

小白怎么入门网络安全?看这篇文章就够啦!(2023最新)

作为一名从业多年的网络安全工程师,我了解到,网络安全是一个高度技术密集的领域,它涵盖了网络架构、网络协议、操作系统、编程语言、密码学、安全漏洞、入侵检测和应急响应等多个方面。如果你是零基础的小白,想要进入这个行业&…

5个设计师必备的页面设计工具!

在现代科技飞速发展的时代,设计软件的选择越来越多。本文将盘点 5 大主流页面设计工具其中,即时设计是一款协同页面设计工具,提供在线编辑和保存等功能,同时拥有免费设计素材和在线留言评论等实用功能。它的云端协作设计使得复杂的…

街电入局两轮电动车充电,讲出了“跃迁”式的新故事?

以共享单车为起点,中国的共享经济正蓬勃发展。国家信息中心披露的数据显示,2022年,中国共享经济市场交易规模约38320亿元,同比增长约3.9%。 虽然同属共享经济,但与部分共享单车企业嫁入“豪门”全身而退不同&#xff…