【Spring 篇】MyBatis中的CRUD魔法:数据之美的四重奏

在这里插入图片描述

MyBatis,这个数据持久化的魔法师,以其优雅的SQL映射和简洁的配置文件,为我们呈现出一场CRUD(Create, Read, Update, Delete)的奇妙之旅。在这篇博客中,我们将深入探讨MyBatis中的增、删、改、查操作,揭示其中的神秘面纱。

数据之美的前奏

在开始我们的CRUD之旅之前,让我们先欣赏一下数据之美的前奏,也就是如何配置和使用MyBatis。首先,我们需要一个简单的实体类User

public class User {private Long id;private String username;private String password;// 省略 getter 和 setter 方法
}

接下来,我们需要为User类编写一个Mapper映射文件UserMapper.xml,定义与User实体类相关的SQL语句。

<!-- UserMapper.xml -->
<mapper namespace="com.example.mapper.UserMapper"><resultMap id="UserResultMap" type="com.example.model.User"><id property="id" column="id" /><result property="username" column="username" /><result property="password" column="password" /></resultMap><select id="getUserById" resultMap="UserResultMap">SELECT * FROM user WHERE id = #{id}</select><insert id="insertUser" parameterType="com.example.model.User">INSERT INTO user (username, password) VALUES (#{username}, #{password})</insert><update id="updateUser" parameterType="com.example.model.User">UPDATE user SET username = #{username}, password = #{password} WHERE id = #{id}</update><delete id="deleteUser" parameterType="java.lang.Long">DELETE FROM user WHERE id = #{id}</delete>
</mapper>

这个Mapper映射文件包含了四个SQL语句,分别对应CRUD的四个操作:查询、插入、更新、删除。接下来,让我们通过代码演示如何使用这些SQL语句进行CRUD操作。

查询之美:Read

查询是CRUD中最常见的操作,也是数据之美的起点。让我们通过MyBatis的select语句,查询用户信息。

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;import java.io.IOException;
import java.io.InputStream;public class MyBatisReadMagic {public static void main(String[] args) {// 读取MyBatis配置文件String resource = "mybatis-config.xml";try (InputStream inputStream = Resources.getResourceAsStream(resource)) {// 创建SqlSessionFactorySqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);// 创建SqlSessiontry (SqlSession sqlSession = sqlSessionFactory.openSession()) {// 执行查询操作User user = sqlSession.selectOne("com.example.mapper.UserMapper.getUserById", 1);// 打印查询结果System.out.println("User ID: " + user.getId());System.out.println("Username: " + user.getUsername());System.out.println("Password: " + user.getPassword());}} catch (IOException e) {e.printStackTrace();}}
}

这段代码首先读取MyBatis配置文件,创建SqlSessionFactory,然后通过SqlSessionFactory创建SqlSession。接着,我们执行了一个查询操作,使用selectOne方法查询ID为1的用户信息。最后,打印查询结果。

插入之美:Create

插入操作是CRUD中的“C”(Create),用于向数据库中新增数据。MyBatis通过insert语句来实现插入操作。

public class MyBatisCreateMagic {public static void main(String[] args) {// 创建一个新用户对象User newUser = new User();newUser.setUsername("Alice");newUser.setPassword("new_password");// 读取MyBatis配置文件String resource = "mybatis-config.xml";try (InputStream inputStream = Resources.getResourceAsStream(resource)) {// 创建SqlSessionFactorySqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);// 创建SqlSessiontry (SqlSession sqlSession = sqlSessionFactory.openSession()) {// 执行插入操作int affectedRows = sqlSession.insert("com.example.mapper.UserMapper.insertUser", newUser);// 提交事务sqlSession.commit();// 打印插入结果System.out.println("Inserted new user. Affected rows: " + affectedRows);}} catch (IOException e) {e.printStackTrace();}}
}

这段代码中,我们首先创建了一个新的User对象,设置了用户名和密码。然后,通过MyBatis的insert语句将这个新用户插入到数据库中。最后,通过commit方法提交事务。

更新之美:Update

更新操作是CRUD中的“U”(Update),用于修改数据库中的数据。MyBatis通过update语句来实现更新操作。

public class MyBatisUpdateMagic {public static void main(String[] args) {// 创建一个待更新的用户对象User updateUser = new User();updateUser.setId(1);  // 假设要更新ID为1的用户信息updateUser.setUsername("UpdatedAlice");updateUser.setPassword("updated_password");// 读取MyBatis配置文件String resource = "mybatis-config.xml";try (InputStream inputStream = Resources.getResourceAsStream(resource)) {// 创建SqlSessionFactorySqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);// 创建SqlSessiontry (SqlSession sqlSession = sqlSessionFactory.openSession()) {// 执行更新操作int affectedRows = sqlSession.update("com.example.mapper.UserMapper.updateUser", updateUser);// 提交事务sqlSession.commit();// 打印更新结果System.out.println("Updated user. Affected rows: " + affectedRows);}} catch (IOException e) {e.printStackTrace();}}
}

这段代码中,我们创建了一个待更新的User对象,设置了新的用户名和密码。然后,通过MyBatis的update语句将这个用户对象的信息更新到数据库中。最后,通过commit方法提交事务。

删除之美:Delete

删除操作是CRUD中的“D”(Delete),用于从数据库中删除数据。MyBatis通过delete语句来实现删除操作。

public class MyBatisDeleteMagic {public static void main(String[] args) {// 待删除用户的IDLong userIdToDelete = 1L;  // 假设要删除ID为1的用户信息// 读取MyBatis配置文件String resource = "mybatis-config.xml";try (InputStream inputStream = Resources.getResourceAsStream(resource)) {// 创建SqlSessionFactorySqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);// 创建SqlSessiontry (SqlSession sqlSession = sqlSessionFactory.openSession()) {// 执行删除操作int affectedRows = sqlSession.delete("com.example.mapper.UserMapper.deleteUser", userIdToDelete);// 提交事务sqlSession.commit();// 打印删除结果System.out.println("Deleted user. Affected rows: " + affectedRows);}} catch (IOException e) {e.printStackTrace();}}
}

这段代码中,我们指定了要删除的用户的ID,然后通过MyBatis的delete语句将该用户从数据库中删除。最后,通过commit方法提交事务。

小结:CRUD的魔法之旅

通过MyBatis的增、删、改、查四个操作,我们深入探索了数据之美的奇妙之旅。MyBatis通过简洁的配置文件和直观的SQL映射,让CRUD操作变得如此优雅。无论是查询、插入、更新还是删除,MyBatis都以其独特的方式为我们展现了数据之美的不同层面。

在这场奇妙的CRUD之旅中,MyBatis是我们的向导,SQL语句是我们的咒语,数据库是我们的舞台。希望通过这篇博客,你能感受到MyBatis中CRUD操作的奇妙之处,为你的数据操作带来更多灵感和理解。让我们继续探索数据之美的未知领域,一起在编码的世界中畅游。

作者信息

作者 : 繁依Fanyi
CSDN: https://techfanyi.blog.csdn.net
掘金:https://juejin.cn/user/4154386571867191

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

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

相关文章

溯流而上:从算盘到现代计算机——计算设备历史与关键人物的探索之旅

Tracing the Evolution: From Abacus to Modern Computers - An Exploratory Journey Through the History of Computing Devices and Key Figures 溯流而上&#xff1a;从算盘到现代计算机——计算设备历史与关键人物的探索之旅 Good day! Today, we embark on a fascinating …

linux基础学习(5):yum

yum是为了解决rpm包安装依赖性而产生的一种安装工具 1.yum源 1.1配置文件位置 yum源的配置文件在/etc/yum.repos.d/中 *Base源是网络yum源&#xff0c;也就是需要联网才能使用的yum源。默认情况下&#xff0c;系统会使用Base源 *Media源是光盘yum源&#xff0c;是本地yum源…

std::atomic

一、概述 std::atomic 是C11引入的一个模板类&#xff0c;用于提供原子操作的类型。在多线程编程中&#xff0c;当多个线程同时访问同一块数据时&#xff0c;可能会导致数据竞争和不确定的行为。std::atomic 可以用来创建原子类型的变量&#xff0c;保证对该变量的操作是原子的…

【leetcode】下一个排列 双指针算法

/*** param {number[]} nums* return {void} Do not return anything, modify nums in-place instead.*/ var nextPermutation function(nums) {const len nums.length;let i len -2;//找到第一个当前项比后一项小的位置iwhile(i>0&&nums[i]>nums[i1]) i--;if(…

(202401)深度强化学习基础2:策略梯度

文章目录 前言策略梯度1 基于价值算法的缺点2 策略梯度算法3 REINFORCE算法本章小结 前言 感谢Datawhale成员的开源本次学习内容的文档地址为 第九章 策略梯度 策略梯度 这个章节会开始介绍基于策略梯度的算法。前面的算法都是针对“奖励”或者说“回报&#xff08;reward&a…

章鱼网络 Community Call #17|打造全新 Omnity 跨链协议

香港时间2024年1月8日12点&#xff0c;章鱼网络举行第17期 Community Call。 对于 Octopus Community 而言&#xff0c;2023年是一个分水岭。我们如期兑现我们的承诺&#xff0c;成功上线了包括 $NEAR Restaking 和 Adaptive IBC 在内的完整的 Octopus 2.0。 自从我们在2023年…

9.2 工厂模式(❤)

9.2 工厂模式(❤) 1. 工厂模式介绍1.1 工厂模式1.2 简单工厂1.2.1 案例讲解: 购买电脑2. 工厂模式用途和特点3. 工厂模式项目应用1. 工厂模式介绍 1.1 工厂模式

HashMap原理

Java面试题 HashMap原理 HashMap是数组链表/红黑树结构&#xff0c;在put元素时会经过以下步骤&#xff1a; 1.先根据key的hashcode计算存储索引。 2.如果数组为空&#xff0c;则先执行resize进行扩容。 3.判断是否存在哈希冲突&#xff0c;如果没有则直接生成链表结构Node放入…

Java便捷访问的好处

便捷访问有以下几个好处&#xff1a; 提高效率&#xff1a;便捷访问可以减少查找和获取信息所需的时间和努力&#xff0c;从而提高工作和生活效率。 增强用户体验&#xff1a;提供便捷访问可以使用户感到方便和满意&#xff0c;从而增强他们对产品或服务的体验。 增加使用频率…

springcloud gateway正确路由配置 uri找不到服务?

引言 在集成nacos组件以及springcloudalibaba 的gateway时&#xff0c;出现正确配置&#xff0c;如下文配置&#xff0c;却在测试demo调用该服务的时候&#xff0c;无法路由到此服务&#xff0c;说是无效服务。经过查阅资料得知其命名不符合gateway的命名规范&#xff0c;因而…

Http三种常见状态码的区别(401、403、500)

一、解释 401 Unauthorized&#xff08;未经授权&#xff09;&#xff1a;表示请求需要进行身份验证&#xff0c;但客户端未提供有效的身份验证凭据。通常&#xff0c;当用户尝试访问需要身份验证的资源时&#xff0c;服务器会返回401状态码&#xff0c;以提示客户端提供有效的…

万界星空科技mes系统可以为企业带来什么好处

随着信息技术的不断发展&#xff0c;MES生产制造系统的作用不断凸显。万界星空科技MES生产制造可以为企业带来四个方面的好处&#xff1a;提升生产效率、降低生产成本、优化生产过程、提高生产质量。本文将从这四个方面分别进行详细阐述&#xff0c;旨在通过对MES生产制造系统的…

动态规划汇总

作者推荐 视频算法专题 简介 动态规划&#xff08;Dynamic Programming&#xff0c;DP&#xff09;是运筹学的一个分支&#xff0c;是求解决策过程最优化的过程。每次决策依赖于当前状态&#xff0c;又随即引起状态的转移。一个决策序列就是在变化的状态中产生出来的&#x…

C#调用C++ dll异常排查

基本情况 最近在做的一款程序&#xff0c;长时间运行总会出现莫名的问题。有时是自动关闭&#xff0c;有时程序报错&#xff0c;有时调用的dll异常…… 提出假设——dll内存泄漏 由于开始与C组合作时&#xff0c;使用其提供的dll出现过数据读写时异常&#xff08;内存操作异常…

线程的创建与回收

目录 一、线程的创建 进程&#xff1a; 线程&#xff1a; 线程特点&#xff1a; 一个进程中的多个线程共享以下资源&#xff1a; 每个线程私有的资源包括&#xff1a; Linux线程库&#xff1a; 线程创建-pthread_create 二、线程的参数传递 线程结束-pthread_exit 线程查…

【论文解读】LERF:语言嵌入的辐射场(ICCV 2023 Oral)

来源&#xff1a;投稿 作者&#xff1a;橡皮 编辑&#xff1a;学姐 论文链接&#xff1a;https://arxiv.org/abs/2303.09553 项目主页&#xff1a;https://lerf.io](https://lerf.io 图 1&#xff1a;语言嵌入辐射场 (LERF)。 LERF 将 CLIP 表示建立在密集、多尺度的 3D 场中。…

Oracle SQL Developer执行sql脚本文件

文件过于大&#xff0c;无法打开&#xff0c;直接在界面执行。 ①将文件放置到D盘&#xff0c;文件名 daochu5.sql ② 在工具执行SQL界面输入 d:\daochu5.sql;,点击运行按钮运行

Shell 脚本实现自动启动程序、日志管理和定时任务监控

简介 本篇将通过Shell 脚本实现自动启动Java程序、日志管理和定时任务监控。脚本启动程序具灵活定制、可移植性和扩展性强的优点&#xff0c;可以根据需要添加额外的功能、配置选项和自定义行为&#xff0c;从而满足更具体的要求。 脚本编写 vim start_program.sh#!/bin/bas…

Swift抓取某网站律师内容并做排名筛选

有个很要好的朋友&#xff0c;今天找我说他的朋友欠他钱&#xff0c;因为工程上面的事情&#xff0c;所以一直没拿到款。想让我找个靠谱的律师帮他打官司&#xff0c;因为这个也不是我的强项&#xff0c;也没有这方面的经验。随即从律师网站爬取对应律师口碑以及成功案例&#…

【第七在线】利用大数据与AI,智能商品计划的未来已来

随着科技的快速发展&#xff0c;大数据和人工智能(AI)已经成为各行各业变革的重要驱动力。在服装行业&#xff0c;这两大技术的结合正在深刻改变着传统的商品计划方式&#xff0c;引领着智能商品计划的未来。 一、大数据与AI在智能商品计划中的角色 大数据为智能商品计划提供了…