MyBatis 动态标签

news/2025/11/1 17:07:16/文章来源:https://www.cnblogs.com/2678066103hs/p/19183566

配置文件示例

#应用程序名称
spring.application.name=configuration
#应用程序端口号
server.port=8080
#数据库连接信息
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/database_name?characterEncoding=utf8&useSSL=false
spring.datasource.username=root
spring.datasource.password=root
#自动驼峰转换
mybatis.configuration.map-underscore-to-camel-case=true
spring:application:#应用程序名称name: configuration#数据库连接信息datasource:url: jdbc:mysql://127.0.0.1:3306/database_name?characterEncoding=utf8&useSSL=falseusername: rootpassword: root
#应用程序端口号
server:port: 8080
mybatis:configuration: map-underscore-to-camel-case: true #自动驼峰转换

CRUD

import com.example.spring_mybatis.model.PersonInfo;
import org.apache.ibatis.annotations.*;@Mapper
public interface BlogMapper {@Select("select * from blog")List<PersonInfo> getPersonInfoAll();@Insert("insert into blog values (#{id},#{name},#{age})")Integer addPerson(PersonInfo person);@Update("update blog set name = #{name},age = #{age} where id = #{id}")Integer updatePerson(PersonInfo personInfo);@Delete("delete from blog where id = #{id}")Integer deletePerson(Integer id);
}

@Param

@Mapper
public interface BlogMapper {//@Param@Update("update blog set name = #{name},age = #{age} where id = #{id}")Integer updatePersonInfo(@Param("id") Integer userId,@Param("name") String userName,@Param("age") Integer userAge);
}

动态SQL

动态sql:指在程序运行时根据条件或参数动态生成的sql语句。与静态sql相比,动态sql更具灵活性,适用于需要更具不同条件构建查询的场景。例如,在某些web/app进行账号注册时会出现非必填选项

  • mybatis的注解和xml两种方式都能实现动态SQL,但xml较为方便,所以下文使用xml来实现动态SQL

trim 标签

作用:用于自定义字符串截取规则,包含四个属性

  • prefix:最终结果添加前缀
  • suffix:最终结果添加后缀
  • prefixOverrides:去除首部指定内容
  • suffixOverrides:去除尾部指定内容

if 标签

作用:用于条件判断,通常在where或set语句中使用,当test表达式的值为true时,包含标签内的SQL片段

    <insert id="addPersonInfo">insert into blog<trim prefix="(" suffix=")" suffixOverrides=","><if test="id != null">id,</if><if test="name != null">name,</if><if test="age != null">age,</if></trim>values<trim prefix="(" suffix=")" suffixOverrides=","><if test="id != null">#{id},</if><if test="name != null">#{name},</if><if test="age != null">#{age},</if></trim></insert>

where 标签

作用:替代SQL中的where关键字,当if条件成立时才会加入sql片段,并自动去掉第一个子句的and / or

<select id="getPersonInfoByNameAndAge">select * from blog<where><if test="name != null">and name = #{name}</if><if test="age != null">and age = #{age}</if></where>
</select>

set 标签

作用:用于update语句。当if条件成立时才会加入SQL片段,并自动去除最后一个子句的逗号、

    <update id="updatePersonInfo">update blog<set><if test="name != null">name = #{name},</if><if test="age != null">age = #{age},</if></set><where>and id = #{id}</where></update>

foreach标签

作用:用于集合遍历。主要属性:

  • collection:集合参数名
  • item:当前元素变量名
  • open/close:包围符号
  • separator:分隔符
    @Testvoid getPersonInfoById() {ArrayList<Integer> ids = new ArrayList<>();ids.add(1);ids.add(2);ids.add(3);List<PersonInfo> personInfoById = blogXMLMapper.getPersonInfoById(ids);System.out.println(personInfoById);}
    <select id="getPersonInfoById" resultType="com.example.spring_mybatis.model_blog.PersonInfo">select * from blogwhere id in<foreach collection="ids" item="id" open="(" close=")" separator=",">#{id}</foreach></select>

include 标签

作用:用于引用SQL片段,通过refid指定要引用的片段id。需配合sql标签使用,实现代码复用

    <sql id="collection">id,name,age</sql><select id="getPersonInfoAll" resultType="com.example.spring_mybatis.model_blog.PersonInfo">select<include refid="collection"></include>from blog</select>

主键返回

主键返回:指在数据库插入操作后,自动获取刚插入记录的主键值。在mybatis中使用注解和xml都能获取到返回的主键

注解实现

@Mapper
public interface BlogMapper {@Options(useGeneratedKeys = true,keyProperty = "id")@Insert("insert into blog values (#{id},#{name},#{age})")Integer addPerson(PersonInfo person);
}@SpringBootTest
@Slf4j
class BlogMapperTest {private final BlogMapper blogMapper;@Autowiredpublic BlogMapperTest(BlogMapper blogMapper) {this.blogMapper = blogMapper;}@Testvoid addPerson() {PersonInfo personInfo = new PersonInfo(null, "黄忠", 60);Integer ret = blogMapper.addPerson(personInfo);log.info("添加成功,影响行数:{},返回的主键值:{}",ret.toString(),personInfo.getId());//添加成功,影响行数:1,返回的主键值:6}
}

通过xml实现

@SpringBootTest
@Slf4j
class BlogXMLMapperTest {private final BlogXMLMapper blogXMLMapper;@Autowiredpublic BlogXMLMapperTest(BlogXMLMapper blogXMLMapper) {this.blogXMLMapper = blogXMLMapper;}@Testvoid addPersonInfo() {PersonInfo personInfo = new PersonInfo();personInfo.setAge(40);personInfo.setName("曹操");Integer ret = blogXMLMapper.addPersonInfo(personInfo);log.info("添加成功,影响行数:{},返回的主键值:{}",ret.toString(),personInfo.getId());//添加成功,影响行数:1,返回的主键值:7}
}
    <insert id="addPersonInfo" useGeneratedKeys="true" keyProperty="id">insert into blog<trim prefix="(" suffix=")" suffixOverrides=","><if test="id != null">id,</if><if test="name != null">name,</if><if test="age != null">age,</if></trim>values<trim prefix="(" suffix=")" suffixOverrides=","><if test="id != null">#{id},</if><if test="name != null">#{name},</if><if test="age != null">#{age},</if></trim></insert>

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

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

相关文章

用 CSS Grid 实现高效布局的 3 个实战技巧

1. 动态网格:auto-fit + minmax() 响应式适配 无需媒体查询!一行代码创建自适应列: .grid-container {display: grid;grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); } auto-fit:自动填充可用空间…

【Linux 高效的系统】文件系统与软硬件连接

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

Webpack技术深度解析:模块打包与性能优化

在前端开发的浩瀚星空中,Webpack无疑是一颗璀璨的明星。作为现代前端工程不可或缺的一部分,Webpack以其强大的模块打包能力和高度的灵活性,赢得了广大开发者的青睐。本文将深入探讨Webpack的核心概念、配置优化以及…

Pinely Round 5 (Div. 1 + Div. 2) A+B+C+D

A.Round Trip原题链接 解题思路简单贪心模拟一下,能减则减AC code void solve(){int r,x,d,n;cin>>r>>x>>d>>n;string s;cin>>s;s="&"+s;int ans=0;for(int i=1;i<=n;…

Spring Web MVC入门 - 指南

Spring Web MVC入门 - 指南pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", …

CSS:现代Web设计的不同技术

CSS(层叠样式表)是为HTML提供样式的主要语言。随着Web的发展,CSS也不断演进,融入了许多新特性和技术,帮助开发者创建更美观和功能丰富的网站。本文将探讨CSS的几种不同技术,包括Flexbox、Grid、动画效果、预处理…

左手坐标系和右手坐标系

左手坐标系和右手坐标系1. 左手坐标系 伸开左手,掌心向外,拇指和食指垂直,弯曲中指、无名指和小指。拇指所指的方向是X轴正方向,食指所指的方向是Y轴正方形,中指、无名指和小指所指的方向是Z轴正方向。 2. 右手坐…

ubuntu24 主题体验经验

一、主题来源网站 https://www.gnome-look.org/s/Gnome/browse?cat=135&page=11&ord=rating 二、主题安装文件夹 & 设置创建文件夹 ~/.themes 下载的主题直接扔到这个文件夹。好处有2 (1) 简单,不用权…

图神经网络(GNN)

一、概念 1、GNN是处理图结构数据的深度学习模型,核心是通过图卷积、注意力机制等操作,让节点学习自身与邻居的关联信息,最终输出节点 / 图的特征或预测结果 2、传统深度学习(CNN、RNN)擅长处理网格数据(如图片)…

docker部署OpenResume 开源简历生成器

采用现代专业设计,符合美国最佳实践,并与 Greenhouse 和 Lever 等主流 ATS 平台兼容。它能自动设置字体、字号、页边距和项目符号格式,确保一致性并避免人为错误。官网:GitHub - xitanggg/open-resume: OpenResume…

深入解析:MySQL 配置管理与日志系统完全指南:从基础到高级优化

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

不使用 AAudio 的前提下,降低 Android 音频传输延时的方案

如果芯片厂未实现 MMAP 驱动接口,那么即使客户端代码调用了 AAudio 接口,也无法降低音频传输延时。因为 AAudio 会回退到以 legacy 模式工作。在芯片驱动不支持使用 AAudio 的前提下,我们可以通过其它方式来减少音频…

深入解析:dmfldr快速装载工具使用

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

OpenAPI 3 所有常用注解的实际用法

OpenAPI 3 所有常用注解的实际用法OpenAPI 3 所有常用注解的实际用法 一个完整的 Spring Boot + SpringDoc 示例,涵盖了 OpenAPI 3 所有常用注解的实际用法,包括接口分组、参数说明、响应结构、模型字段描述、隐藏接…

LINQ 表达式详解

1. 基础概念与用法 1.1 什么是 LINQ? LINQ 是 .NET Framework 3.5 引入的一项特性,它将查询能力直接集成到 C# 语言中。通过 LINQ,你可以像写 SQL 一样对内存中的集合(如 List<T>、数组)或外部数据源(如数…

任务---网络通信组件JsonRpc

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

K230使用RTSP实现无线图传

K230 使用 RTSP 实现无线图传 效果图开发环境开发板:LCKFB-LSPI-K230-1G-CanMV 固件:CanMV_K230_LCKFB_micropython_v1.4-0-g6cce59c_nncase_v2.9.0.img IDE:CanMV K230 播放器:VLC 播放器RTSP 介绍 RTSP(Real-Time S…

英语背单词 专八词汇 中英对照 2025年11月

2025-11-022025-11-01Index Word Pronunciation Parts of Speech Explanation Translation in Chinese1 lineage /ˈlɪnɪɪdʒ/ noun A line of descendants from a particular ancestor; ancestry or heritage; fam…

CodeForces-2138B Antiamuny Wants to Learn Swap

tag: *1900;逆序对,单调栈,双指针,线段树CodeForces-2138B Antiamuny Wants to Learn Swap tag: *1900;逆序对,单调栈,双指针,线段树对于长度为 \(m\) 的数组 \(b\),你可以进行以下两种操作:选择一个下标 \(…

EVA 个人总结

新剧场版设定总结【防止与TV混淆】 第一次冲击 莉莉丝引发并孕育出人类 第二次冲击 南极对Adams的研究 使徒的目标:融合莉莉丝实现进化(会引发第三次冲击) 第四使徒 水天使 真嗣的第一次战斗-初号机暴走 第五使徒 昼…