Java实战:使用XML与注解方式实现CRUD操作

本文将详细介绍如何使用MyBatis框架,通过XML映射文件和注解两种方式来实现数据库的增删改查(CRUD)操作。我们将探讨MyBatis的配置和使用方法,并通过一个具体示例来演示如何使用XML和注解来完成基本的数据库操作。本文适合希望学习MyBatis或提高数据库操作效率的Java开发者阅读。

一、引言

MyBatis是一个优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。MyBatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集的工作。MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJOs(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录。

二、MyBatis环境搭建

在开始使用MyBatis之前,我们需要搭建相应的开发环境。这里我们以一个Maven项目为例,介绍如何添加MyBatis依赖。
1. 添加MyBatis依赖
在项目的pom.xml文件中,添加MyBatis和数据库驱动的依赖:

<dependencies><!-- MyBatis --><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.5.6</version></dependency><!-- MySQL驱动 --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.22</version></dependency>
</dependencies>

2. 配置MyBatis
在项目的资源目录下,创建一个名为mybatis-config.xml的配置文件,用于配置MyBatis的基本设置:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><environments default="development"><environment id="development"><transactionManager type="JDBC"/><dataSource type="POOLED"><property name="driver" value="com.mysql.cj.jdbc.Driver"/><property name="url" value="jdbc:mysql://localhost:3306/test_db?useSSL=false"/><property name="username" value="root"/><property name="password" value="root"/></dataSource></environment></environments><mappers><mapper resource="com/example/demo/mapper/UserMapper.xml"/></mappers>
</configuration>

三、使用XML实现CRUD操作

1. 创建实体类
首先,我们需要创建一个与数据库表对应的实体类。例如,我们创建一个User类:

public class User {private Integer id;private String name;private Integer age;// getter和setter方法
}

2. 创建Mapper接口
接下来,我们创建一个UserMapper接口,用于定义数据库操作方法:

public interface UserMapper {int insert(User user);int update(User user);int delete(Integer id);User selectById(Integer id);List<User> selectAll();
}

3. 创建XML映射文件
在资源目录下,创建一个名为UserMapper.xml的映射文件,用于编写SQL语句和映射关系:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.demo.mapper.UserMapper"><insert id="insert" parameterType="com.example.demo.entity.User">INSERT INTO user (name, age) VALUES (#{name}, #{age})</insert><update id="update" parameterType="com.example.demo.entity.User">UPDATE user SET name = #{name}, age = #{age} WHERE id = #{id}</update><delete id="delete" parameterType="java.lang.Integer">DELETE FROM user WHERE id = #{id}</delete><select id="selectById" parameterType="java.lang.Integer" resultType="com.example.demo.entity.User">SELECT * FROM user WHERE id = #{id}</select><select id="selectAll" resultType="com.example.demo.entity.User">SELECT * FROM user</select>
</mapper>

四、使用注解实现CRUD操作

除了使用XML映射文件,MyBatis还支持使用注解来实现CRUD操作。
1. 修改Mapper接口
在Mapper接口

    @Insert("INSERT INTO user (name, age) VALUES (#{name}, #{age})")int insert(User user);@Update("UPDATE user SET name = #{name}, age = #{age} WHERE id = #{id}")int update(User user);@Delete("DELETE FROM user WHERE id = #{id}")int delete(Integer id);@Select("SELECT * FROM user WHERE id = #{id}")User selectById(Integer id);@Select("SELECT * FROM user")List<User> selectAll();
}

2. 修改MyBatis配置
mybatis-config.xml中,我们需要将XML映射文件的配置替换为注解扫描的配置:

<mappers><mapper class="com.example.demo.mapper.UserMapper"/>
</mappers>

五、具体示例

现在,我们将通过一个具体示例来演示如何使用MyBatis实现CRUD操作。
1. 创建SqlSessionFactory
使用MyBatis的SqlSessionFactoryBuilder来创建SqlSessionFactory

String resource = "org/mybatis/example/mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

2. 创建SqlSession
通过SqlSessionFactory来创建SqlSession

SqlSession session = sqlSessionFactory.openSession();

3. 使用Mapper
通过SqlSession获取Mapper接口的代理实例:

UserMapper mapper = session.getMapper(UserMapper.class);

现在,我们可以使用mapper对象来执行CRUD操作了:

// 创建新用户
User newUser = new User("John Doe", 30);
mapper.insert(newUser);
// 更新用户
newUser.setAge(31);
mapper.update(newUser);
// 删除用户
mapper.delete(newUser.getId());
// 查询单个用户
User user = mapper.selectById(newUser.getId());
// 查询所有用户
List<User> users = mapper.selectAll();

4. 提交事务并关闭SqlSession

session.commit();
session.close();

六、总结

通过本文,我们介绍了如何使用MyBatis框架,通过XML映射文件和注解两种方式来实现数据库的增删改查操作。我们首先搭建了MyBatis的开发环境,然后分别使用了XML和注解来实现User表的CRUD操作。MyBatis提供了灵活的配置和使用方式,使得数据库操作更加简洁和高效。希望本文能够帮助您更好地理解和使用MyBatis,如果您有任何疑问或建议,请随时留言交流。
请注意,本文中的代码示例仅用于演示目的,实际应用中可能需要根据具体需求进行调整和完善。

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

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

相关文章

代码随想录刷题笔记-Day20

1. 二叉树的最近公共祖先 236. 二叉树的最近公共祖先https://leetcode.cn/problems/lowest-common-ancestor-of-a-binary-tree/ 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为&#xff1a;“对于有根树 T 的两个节点 p、q&#x…

力扣 面试题 05.06. 整数转换

思路&#xff1a; 牵扯到二进制数&#xff0c;基本上要考虑位运算符&#xff0c;相关知识可以见http://t.csdnimg.cn/fzts7 之前做过类似的题目&#xff0c;大致思路就是先用按位异或^找出不同位&#xff0c;再用n&&#xff08;n-1&#xff09;计算出不同位的个数&#x…

Nginx的流式响应配置

Nginx的流式响应配置 使用ChatGPT的能力在聊天时来实现打字机效果&#xff0c;因此需要服务端接口进行流式响应&#xff0c;碰到了几个问题&#xff1a; 1、服务端明明配置了响应头的Content-Type为&#xff1a;text/event-stream&#xff0c;但前端仍然不是流式接收内容。 2、…

在VsCode中通过Cookie登录LeetCode

在vscode中配置好leetcode之后&#xff0c;一般最常用的就是通过cookie登录leetcode ; 首先点击sign in &#xff0c; 然后选择最下面的 &#xff0c; LeetCode Cookie ! 然后输入username(也就是你的lc用户名) 或者 你leetcode绑定的邮箱 ; 输入完成之后 ; 就是要你输入你的l…

vue+element (el-progress)标签 隐藏百分比(%) ,反向显示 ,自定义颜色, demo 复制粘贴拿去用

1 效果: 2 页面代码: <el-row :gutter"10" ><el-col :span"12"><el-card ><div class"fourqu"><div><span slot"title">{{推送任务TOP5}}</span></div></div><div class&…

C++程序设计学习笔记(一)

目录 1.C语言简介 1.C语言发展简史 1.机器语言 2.汇编语言 3.高级语言 4.C语言发展简史 5.C和C语言的关系 2.C语言的特点 1.基本的输入输出 1.C中的输入流和输出流 2.标准的hellworld代码 3.简单的输输出函数 2.头文件和命名空间 1.头文件 2.命名空间 …

[Mac软件]Mac上的最佳3D建模工具-犀牛Rhinoceros 8 for Mac v8.4.24044.1500完美兼容激活

【黑果魏叔】Rhino 8是一款由美国Robert McNeel & Assoc开发的强大的专业3D造型软件&#xff0c;广泛应用于三维动画制作、工业制造、科学研究以及机械设计等领域。它可以轻松整合3DS MAX与Softimage的模型功能部分&#xff0c;对精细、弹性与复杂的3D NURBS模型具有高效的…

【RT-DETR有效改进】大核注意力 | LSKAttention助力极限涨点

一、本文介绍 在这篇文章中,我们将讲解如何将LSKAttention大核注意力机制应用于RT-DETR,以实现显著的性能提升。首先,我们介绍LSKAttention机制的基本原理,它主要通过将深度卷积层的2D卷积核分解为水平和垂直1D卷积核,减少了计算复杂性和内存占用。接着,我们介绍将这一…

布客深度学习译文集 2024.2 更新

Sklearn、TensorFlow 与 Keras 机器学习实用指南第三版Sklearn 与 TensorFlow 机器学习实用指南第二版PyTorch 自然语言处理Transformer 和扩散模型的生成式 AI 实用指南&#xff08;预览版&#xff09;Transformer 自然语言处理面向程序员的 FastAI 和 PyTorch 深度学习Tensor…

MySQL篇—事务和隔离级别介绍

☘️博主介绍☘️&#xff1a; ✨又是一天没白过&#xff0c;我是奈斯&#xff0c;DBA一名✨ ✌✌️擅长Oracle、MySQL、SQLserver、Linux&#xff0c;也在积极的扩展IT方向的其他知识面✌✌️ ❣️❣️❣️大佬们都喜欢静静的看文章&#xff0c;并且也会默默的点赞收藏加关注❣…

SG-8201CJA(汽车可编程晶体振荡器)

爱普生的SG-8021CJA是一款符合AEC-Q100标准的晶体振荡器&#xff0c;专为要求苛刻的汽车/ADAS应用&#xff08;如激光雷达和相机ECU&#xff09;而设计。它采用爱普生的内部低噪声小数NPLL&#xff0c;输出 频率高达170MHz&#xff0c;相位抖动小于1/25&#xff0c;稳定性比之前…

【前端素材】推荐实用的后台管理系统ebazer电商平台模板(附带源码)

一、需求分析 后台管理系统网站是指用于管理和控制网站、应用程序或系统后台运行的管理工具。它通常是网站或应用程序的管理者、管理员或内容编辑人员使用的界面&#xff0c;具有一系列功能来管理用户、内容、数据和系统设置。以下是后台管理系统网站的功能和特点&#xff1a;…

Mqtt qs 消息可靠性分析

什么是QoS 很多时候,使用MQTT协议的设备都运行在网络受限的环境下,而只依靠底层的TCP传输协议,并不能完全保证消息的可靠到达。因此,MQTT提供了QoS机制,其核心是设计了多种消息交互机制来提供不同的服务质量,来满足用户在各种场景下对消息可靠性的要求。 MQTT定义了三个Q…

Open Systems Interconnection(开放式系统互联)

OSI&#xff08;Open Systems Interconnection&#xff0c;开放式系统互联&#xff09;模型是一个描述计算机网络体系结构和通信系统的参考模型&#xff0c;它将计算机网络分成七个抽象的层级&#xff0c;每个层级负责不同的功能&#xff0c;从物理连接到最终的应用程序。以下是…

动态规划--买卖股票的最佳时机的6种变形

代码随想录中对6种变形做了详细的对比和分析&#xff0c;记录如下&#xff0c;模板是固定的。 121. 买卖股票的最佳时机 class Solution { public:int maxProfit(vector<int>& prices) {vector<vector<int>> dp(prices.size(), vector<int>(2,0)…

CapCut - 剪映国际版11.1.0

​【应用名称】&#xff1a;CapCut - 剪映国际版 【适用平台】&#xff1a;#Android 【软件标签】&#xff1a;#CapCut #剪映国际版 【应用版本】&#xff1a;11.1.0 【应用大小】&#xff1a;231MB 【软件说明】&#xff1a;软件升级更新。目前大家广泛使用的最令人惊叹、最专…

token的理解和代码,token是什么?

面试场景&#xff1a; 以前有个学生去面试&#xff0c;公司问他&#xff0c;如果你们公司的接口文档被你的亲戚看到了&#xff0c;会怎么样&#xff1f;会导致什么问题&#xff0c;为了防止这个问题&#xff0c;需要用什么来解决&#xff1f;这个根据学生回忆的写的。 学生当…

小程序--loading和toast

一、loading wx.showLoading({})显示loading提示框。wx.hideLoading({})隐藏loading提示框。 title&#xff1a;文字提示内容 mask&#xff1a;是否显示透明蒙层&#xff0c;防止触摸穿透。 更多属性参考showLoading官方文档。 wx.showLoading({title: 加载中...,mask: true }…

力扣面试150 验证回文串 双指针 Character API

Problem: 125. 验证回文串 文章目录 思路复杂度Code 思路 &#x1f468;‍&#x1f3eb; 参考题解 Character.isLetterorDigit(char c)&#xff1a;判读字符 c 是否是字母或者数字 Character.toLowerCase(char c)&#xff1a;将字符 c 转换为小写字母 复杂度 时间复杂度: …

docker (八)-dockerfile制作镜像

一 dockerfile dockerfile通常包含以下几个常用命令&#xff1a; FROM ubuntu:18.04 WORKDIR /app COPY . . RUN make . CMD python app.py EXPOSE 80 FROM 打包使用的基础镜像WORKDIR 相当于cd命令&#xff0c;进入工作目录COPY 将宿主机的文件复制到容器内RUN 打包时执…