news 2026/6/7 14:25:06

javaWeb从入门到进阶(MyBatis拓展)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
javaWeb从入门到进阶(MyBatis拓展)

XML映射文件

我们要先知道xml是什么:是一种标记语言,就像HTML的"表哥"。

XML映射文件:XML映射文件是连接Java对象和数据库表的"翻译官"

Q:XML映射文件是干嘛的?
A:它是MyBatis的"大脑",告诉MyBatis:

  1. 执行什么SQL(查询、插入、更新、删除)

  2. 如何传参数(Java对象属性 → SQL参数)

  3. 如何转结果(数据库记录 → Java对象)

  4. 何时变化SQL(根据条件动态调整)

没有它,MyBatis就不知道该如何操作数据库!它是连接Java世界和SQL世界的桥梁。

规范
XML映射文件的名称与Mapper接口名称一致,并且将XML映射文件和Mapper接口放置在相同包下(同包同名)XML映射文件的namespace属性为Mapper接口全限定名一致。
XML映射文件中sql语句的id与Mapper接口中的方法名一致,并保持返回类型一致。

操作:

首先在resource文件夹下创建包名与mapper接口一样的文件夹,用/分隔,然后在其中创建xml类,并在其中配置xml约束。

<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="这里写你的Mapper接口全限定名"> <!-- 你的SQL语句写在这里 --> </mapper>

在xml文件中配置sql语句

Mapper接口

采用注解的方式sql语句是配置在Mapper接口中的,而我们采用xml文件方式是配置在xml类中的。

MyBatis找到并执行SQL的步骤:

  1. 配置阶段:MyBatis读取配置文件,注册Mapper

  2. 运行时:通过接口全名找到对应XML文件

  3. 方法调用:通过方法名找到XML中的SQL标签

  4. 执行SQL:绑定参数,执行预编译SQL

  5. 结果映射:将结果集映射为Java对象

可以安装MybatisX来提高效率。

使用Mybatis的注解,主要是来完成一些简单的增删改查功能。如果需要实现复杂的SQL功能,建议使用XML来配置映射语句。
官方说明:https://mybatis.net.cn/getting-started.html

动态SQL


随着用户的输入或外部条件的变化而变化的SQL语句,我们称为动态SQL。

<if>:用于判断条件是否成立。使用test属性进行条件判断,如果条件为true,则拼接SQL。

如果多余and 和where时,我们采取两个<where>进行包裹,他会自动删除多余部分,方便。

案例分析


完善更新员工功能,修改为动态更新员工数据信息
需求
动态更新员工信息,如果更新时传递有值,则更新;如果更新时没有传递值,则不更新。
解决方案
动态SQL

<set>:动态地在行首插入SET关键字,并会删掉额外的逗号。(用在update语句中)

foreach

collection:遍历的集合

item:遍历出来的元素

separator:分隔符

open:遍历开始前拼接的SQL片段

close:遍历结束后拼接的SQL片段

在mapper.xml中定义接口方法。

在测试类中调用

<sql:定义可重用的SQL片段。
<include>:通过属性refid,指定包含的sql片段。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/3 16:29:13

基于ModbusPoll的温控器测试:实战案例分享

以下是对您提供的博文内容进行 深度润色与结构化重构后的技术文章 。整体风格更贴近一位资深嵌入式系统工程师在技术社区中的真实分享&#xff1a;语言自然、逻辑递进、重点突出、去AI感强&#xff0c;同时强化了工程实践细节、调试直觉和可复用经验&#xff0c;删减冗余套话…

作者头像 李华
网站建设 2026/5/28 17:30:05

麦橘超然踩坑记录:CUDA内存不足怎么办?

麦橘超然踩坑记录&#xff1a;CUDA内存不足怎么办&#xff1f; 用“麦橘超然 - Flux 离线图像生成控制台”跑第一张图时&#xff0c;屏幕突然弹出红色报错&#xff1a;CUDA out of memory。不是模型没加载成功&#xff0c;不是端口被占&#xff0c;更不是代码写错了——是显存…

作者头像 李华
网站建设 2026/6/5 1:59:48

2024最新Unity资源提取工具零基础入门指南

2024最新Unity资源提取工具零基础入门指南 【免费下载链接】AssetRipper GUI Application to work with engine assets, asset bundles, and serialized files 项目地址: https://gitcode.com/GitHub_Trending/as/AssetRipper Unity资源提取工具是一款专为新手设计的资源…

作者头像 李华
网站建设 2026/5/20 19:57:20

Super Resolution技术内幕:DNN SuperRes模块调用机制解析

Super Resolution技术内幕&#xff1a;DNN SuperRes模块调用机制解析 1. 为什么传统放大总显得“假”&#xff1f;——超分辨率的本质突破 你有没有试过把一张手机拍的老照片放大三倍&#xff1f;用Photoshop双线性插值&#xff1f;结果大概率是&#xff1a;边缘发虚、细节糊…

作者头像 李华
网站建设 2026/5/20 19:57:24

5个步骤解锁开源游戏模拟器:在任何设备上畅玩主机游戏

5个步骤解锁开源游戏模拟器&#xff1a;在任何设备上畅玩主机游戏 【免费下载链接】sudachi Sudachi is a Nintendo Switch emulator for Android, Linux, macOS and Windows, written in C 项目地址: https://gitcode.com/GitHub_Trending/suda/sudachi 你是否曾遇到想…

作者头像 李华
网站建设 2026/5/23 13:35:57

3个秘诀让你高效管理网页剪藏:从痛点到完美工作流

3个秘诀让你高效管理网页剪藏&#xff1a;从痛点到完美工作流 【免费下载链接】siyuan A privacy-first, self-hosted, fully open source personal knowledge management software, written in typescript and golang. 项目地址: https://gitcode.com/GitHub_Trending/si/si…

作者头像 李华