MyBatis 执行流程详解及示例代码

news2024/10/6 10:31:36

导言:

MyBatis 是一个优秀的持久层框架,它简化了数据库操作的开发过程。本文将详细介绍 MyBatis 的执行流程,并提供相应的示例代码,帮助读者更好地理解和应用 MyBatis。

1. 创建 SqlSessionFactoryBuilder 对象

在 MyBatis 中,首先需要创建一个 SqlSessionFactoryBuilder 对象,并加载 MyBatis 的配置文件。这个对象用于构建 SqlSessionFactory。

InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
SqlSessionFactory factory = builder.build(inputStream);
  • Resources.getResourceAsStream("mybatis-config.xml"):这行代码使用 MyBatis 提供的 Resources 类,通过指定的路径获取配置文件 mybatis-config.xml 的输入流。该配置文件包含了 MyBatis 的配置信息,如数据库连接、映射文件路径等。

  • SqlSessionFactoryBuilder:这行代码创建了一个 SqlSessionFactoryBuilder 对象,用于构建 SqlSessionFactory

  • builder.build(inputStream):这行代码通过调用 builder 对象的 build 方法,传入配置文件的输入流 inputStream,来构建并返回一个 SqlSessionFactory 实例。

2. 创建 SqlSession 对象

通过 SqlSessionFactory 创建 SqlSession 对象,SqlSession 是 MyBatis 与数据库交互的关键对象。

  • factory.openSession():这行代码通过调用 SqlSessionFactoryopenSession() 方法来创建一个 SqlSession 对象。SqlSession 是 MyBatis 的核心接口,用于执行 SQL 语句并管理数据库连接。
SqlSession session = factory.openSession();

3. 执行 SQL 语句


在 SqlSession 中,可以执行各种 SQL 语句,包括查询、插入、更新和删除操作。

- 查询操作:

List<User> userList = session.selectList("com.example.mapper.UserMapper.getAllUsers");

- 插入操作:

User user = new User("John", 25);
session.insert("com.example.mapper.UserMapper.insertUser", user);
session.commit();

- 更新操作:

User user = session.selectOne("com.example.mapper.UserMapper.getUserById", 1);
user.setName("Jane");
session.update("com.example.mapper.UserMapper.updateUser", user);
session.commit();

- 删除操作:

session.delete("com.example.mapper.UserMapper.deleteUser", 1);
session.commit();

4. 映射文件定义


在执行 SQL 语句之前,需要通过映射文件定义 SQL 语句与 Java 对象的映射关系。映射文件通常使用 XML 格式编写,并与 Java Mapper 接口关联。

示例映射文件 `UserMapper.xml`:

<mapper namespace="com.example.mapper.UserMapper">
    <select id="getAllUsers" resultType="com.example.model.User">
        SELECT * FROM users
    </select>
    
    <insert id="insertUser" parameterType="com.example.model.User">
        INSERT INTO users (name, age) VALUES (#{name}, #{age})
    </insert>
    
    <update id="updateUser" parameterType="com.example.model.User">
        UPDATE users SET name = #{name} WHERE id = #{id}
    </update>
    
    <delete id="deleteUser" parameterType="int">
        DELETE FROM users WHERE id = #{id}
    </delete>
</mapper>

5. 事务管理和异常处理


在 MyBatis 中,可以通过事务管理机制来确保数据操作的一致性和完整性。在操作中捕获异常,并在出现异常时进行事务回滚。

try {
    // 执行数据库操作
    session.insert("com.example.mapper.UserMapper.insertUser", user);
    session.commit();
} catch (Exception e)

 {
    // 异常处理和事务回滚
    session.rollback();
}

总结:


本文介绍了 MyBatis 的执行流程,从创建 SqlSessionFactoryBuilder 到执行 SQL 语句,并介绍了映射文件的定义和事务管理的使用。MyBatis 是一个强大且灵活的持久层框架,通过了解其执行流程,可以更好地应用于实际项目中。

扩展阅读:


- MyBatis 官方文档:https://mybatis.org/mybatis-3/zh/index.html
- MyBatis GitHub 仓库:https://github.com/mybatis/mybatis-3

希望这篇博客能对您有所帮助,如有任何疑问,欢迎随时向我提问。

 

 

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

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

相关文章

基于redis的bitmap实现签到功能(后端)

项目环境 MacOS springboot: 2.7.12 JDK 11 maven 3.8.6 redis 7.0.11 StringRedisTemplate 的key和value默认都是String类型 可以避免不用写配置类&#xff0c;定义key和value的序列化。 实现逻辑&#xff1a; 获取用户登录信息 根据日期获取当天是多少号 构建…

【服务器数据恢复】热备盘同步失败导致服务器崩溃的数据恢复案例

服务器数据恢复环境&#xff1a; 两组分别由4块SAS硬盘组建的raid5磁盘阵列&#xff0c;ext3文件系统&#xff0c;通过LVM管理磁盘存储。 服务器故障&#xff1a; 一组raid5磁盘阵列中的1块硬盘故障离线&#xff0c;热备盘成功启用并开始同步数据&#xff0c;在同步还没有完成…

互联网保险驶入发展快车道,元保保险加速数字化突围

随着90后、00后这一群体逐渐进入婚育高峰期,加之相较60后、70后群体,这群互联网原住民已经成为保险消费的主力人群,互联网保险行业迎来了新的发展机遇,互联网平台恰似曾经辉煌的大卖场、集市、商场,成为汇聚流量的新平台,只不过,能量的漩涡更大,更聚焦。对此,元保集团创始人兼C…

记录一个Masonry 添加约束导致的label 文案展示不全的问题

问题如图&#xff0c;蓝色label 中的文字没有展示完全&#xff0c;后面还有“情。” 原因&#xff0c;我们使用masonry 布局的时候&#xff0c;宽度会有细微的误差&#xff0c;导致我们实际 添加的约束比我们期望的要小&#xff0c;就导致横向无法容下期望的文字宽度&#xf…

如何使用MySQL统计当月每日收益金额

如果要实现上图这个效果&#xff0c;这个SQL应该怎么写呢&#xff1f; 目录 1、实现思路 2、SQL实现 1、实现思路 首先&#xff0c;我们先实现查询当月每日的日期 。然后将查询结果与需要统计的表进行左连接即可。 SELECT DATE(DATE_SUB(CURRENT_DATE(), INTERVAL (DAY(CURRE…

微服务springcloud 10.config配置中心框架和rabbitmq的安装

config配置中心的作用&#xff1a;项目的yml 配置文件保存到 git 服务器&#xff0c;例如 github.com 或 gitee.com 微服务启动时&#xff0c;从服务器获取配置文件 1.新建 “Project”,命名为 config。注意这里的不是maven项目&#xff0c;而是project 2.将sp02,sp03,sp04,s…

git常用命令之Fetch

4. Fetch 命令-----------------------------------------------------------------------------作用延展阅读git fetch1. 拉取「远程仓库」的所有远程分支的最新Commit-ID 记录在 .git/FETCH_HEAD 文件中.若有多个分支则 FETCH_HEAD 内会有多行数据&#xff0c;该文件首行对应…

dbca添加实例时无法发现对方主机

有个12.2集群环境&#xff0c;需要添加一个实例&#xff0c;直接图形化启动dbca&#xff0c;第四步时只能发现本机&#xff0c;无法识别到另外一个节点&#xff0c;如下图 通过排查发现是oracle用户的密码过期了&#xff0c;细节如下 [roothydb1 ~]# su - grid Last login: W…

C++11关键字

decltype 根据表达式的类型自动推导类型 int main(void) {decltype(x) c 21.1; //赋值decltype((x)) d c; // 是一个引用decltype(x) e c; //d 120;cout << sizeof(int) << endl;cout << sizeof(c) << " c" << c << endl;…

【Rust】所有权

文章目录 所有权stack与heap所有权存在的原因所有权规则变量作用域String类型内存和分配变量与数据交互的方式1.Move2.Clone3.Copy 所有权与函数返回值与作用域引用借用可变引用悬空引用Dangling References引用的规则切片字符串切片将字符串切片作为参数传递其他类型的切片 所…

1.2 matlab信号分析编程基础

1.画正弦波 xlinspace(0,2*pi,100); ysin(x); plot(x,y);2.画方波 xlinspace(0,4*pi,100); ysquare(x); plot(x,y);3.矩阵赋值 4.标准函数 5.画图 title&#xff1a;标题 grid&#xff1a;开关网格线 叠加多条曲线 3.GUI画正弦波 Fs 44100; dt 1.0/Fs; T 1; N T/dt…

Acer宏碁笔记本电脑Aspire蜂鸟FUN S50-51原装Windows10系统镜像,恢复出厂系统

Acer宏碁笔记本电脑Aspire蜂鸟S50-51原厂Win10系统工厂模式恢复原装出厂OEM系统 系统自带所有驱动、办公软件、出厂主题壁纸LOGO、 Acer Care Center、Quick Access等预装程序 所需工具&#xff1a;32G或以上的U盘&#xff08;非必需&#xff09; 文件格式&#xff1a;多个I…

Java垃圾搜集算法和垃圾回收算法

垃圾回收主要针对的是JVM的堆内存&#xff0c;分为新生代和老年代。 按照以前的叫法&#xff0c;还有一个永久代&#xff0c;它在方法区里保存了class信息、静态变量、常量池等。 从jdk-1.8开始&#xff0c;方法区的实现发生了一些变化&#xff0c;取消了永久代的概念&#xff…

墨迹api实现天气预测

文章目录 需求背景解决效果接口地址index.vueweather.vue图标文件 视频效果 需求背景 使用墨迹天气api实现天气预报&#xff0c;空气质量预报功能 解决效果 接口地址 墨迹天气 index.vue <template><div class"dqhjjc-wrap"><div class"fir…

pytorch快速入门中文——03

神经网络 原文&#xff1a;https://pytorch.org/tutorials/beginner/blitz/neural_networks_tutorial.html#sphx-glr-beginner-blitz-neural-networks-tutorial-py 可以使用torch.nn包构建神经网络。 现在您已经了解了autograd&#xff0c;nn依赖于autograd来定义模型并对其进…

win10系统打开程序和功能的几种方式介绍

一&#xff0c;简介 在工作中常常会用到安装和卸载软件的功能&#xff0c;需要打开“程序和功能”&#xff0c;本文主要介绍如几种打开“程序和功能”的方法&#xff0c;供参考。 二&#xff0c;四种方法介绍 四种方法分别是&#xff1a; 从控制面板打开&#xff1b;通过运…

VsCode尝试在目标目录创建文件时发生一个错误

桌面右击vscode图标以管理员身份运行就可以了 结束语&#xff1a; 希望这篇文章能帮助到大家&#xff0c;如有不对之处&#xff0c;还请指正。愿我们一起成长。

按unicode值比较数组中的字符串元素numpy.compare_chararrays()方法

【小白从小学Python、C、Java】 【计算机等考500强证书考研】 【Python-数据分析】 对比两个数组中对应位置 的元素的unicode值大小 numpy.compare_chararrays() [太阳]选择题 关于以下代码的输出结果是? import numpy as np a np.array(["a","B","…

联邦聚合(FedAvg、FedProx、SCAFFOLD)

目录 联邦聚合算法对比(FedAvg、FedProx、SCAFFOLD) 解决问题 FedAvg FedProx SCAFFOLD 实验结果 联邦聚合算法对比(FedAvg、FedProx、SCAFFOLD) 论文链接&#xff1a; FedAvg&#xff1a;Communication-Efficient Learning of Deep Networks from Decentralized Data …

在线预览文件

当我们前端小伙伴在码代码的时候&#xff0c;总会不约而同地遇到一个问题&#xff1a;上传文件。一旦文件成功上传&#xff0c;后端就会慷慨地给我们一个下载地址&#xff0c;这是怎么实现在线预览或者直接下载呢&#xff1f;fliencn 是后端给的地址这种是另外起一个标签页预览…