当前位置: 首页 > news >正文

动态 SQL

        动态 SQL 是 MyBatis 的强大特性之一,能够完成不同条件下不同的 sql 拼接。也就是说执行的 SQL 语句并不是固定的,而是不同人的不同操作执行的语句会有所差异。MyBatis 通过使用 标签 的方式来实现这种灵活性的。

<if>标签

        例如在有一些网站进行注册的时候,会要求必须输入邮箱、密码,而那些年龄性别什么的则并不是必填项。这种场景下往数据库插入就可以使用 <if> 标签来实现。

UserMapper:

int addUser2(UserEntity user);

UserMapper.xml:

    <insert id="addUser2">insert into userinfo(username,<if test="photo != null">photo,</if>password) values (#{username},<if test="photo != null">#{photo},</if>#{password})</insert>

单元测试 验证:

添加 photo 属性:

不添加 photo 属性:

<trim>标签

prefix:前缀,如果后面有东西不为空就加上

suffix: 后缀,如果后面有东西不为空就加上
prefixOverrides: 要去除掉的前缀,如果存在的话
suffixOverrides: 要去除掉的后缀,如果存在的话

        假设现在有种情况:全部数据都是非必传的,其中有一个数据传过来了,但是后面没数据就会导致 SQL 语句中多出来了一个 , 逗号就会导致报错。

        为了解决这一问题就可以使用 <trim> 标签。这相当于是完善了 <if> 标签存在的不足。

<where> 标签

        假设现在需要使用 where 条件进行对 id 或者 title 进行文章查询,使用 <trim> 标签实现:

        使用 <where> 标签可以更加简单地表示(更加优雅的方式):

<set>标签

        用在 update 修改操作里面的,跟 <where> 的使用一样,如果不传的话就不会生成,但是没有 set 的 update 是一个错误的 sql 语句,程序会报错。        

<foreach>标签

collection:绑定⽅法参数中的集合,即表示需要 foreach 的是谁

item: 遍历时的每⼀个对象,每次循环的是什么
open: 语句块开头的字符串
close: 语句块结束的字符串
separator: 每次遍历之间间隔的字符串

        当需要批量进行 添加、删除、修改 数据库的时候使用。下面是根据文章 id 来删除文章:

http://www.lryc.cn/news/374612.html

相关文章:

  • 功能强大的多功能文档转换工具Neevia Document Converter Pro 7.5.0.241
  • 从零到一,深入浅出大语言模型的奇妙世界
  • ESP8266发送WOL幻数据包实现电脑远程唤醒
  • 用一个ESP32S3-Zero把有线键盘变为无线
  • Redis 7.x 系列【3】多种连接方式
  • 数据结构(DS)C语言版:学习笔记(4):线性表
  • Linux 命令大全
  • [华为北向网管NCE开发教程(6)消息订阅
  • 2024.6.15 英语六级 经验与复盘
  • 计算机专业的未来展望
  • Shell变量的高级用法
  • 【Python/Pytorch - 网络模型】-- SVD算法
  • 全光万兆时代来临:信而泰如何推动F5G-A(50PONFTTR)技术发展
  • 港科夜闻 | 香港科大与香港科大(广州)合推红鸟跨校园学习计划,共享教学资源,促进港穗学生交流学习...
  • 基于Wireshark实现对FTP的抓包分析
  • Vue54-浏览器的本地存储webStorage
  • Linux下Shell脚本基础知识
  • 爬虫初学篇——看完这些还怕自己入门不了?
  • [数据集][目标检测]减速区域检测数据集VOC+YOLO格式1654张1类别
  • OpenGL3.3_C++_Windows(8)
  • GPU的工作原理
  • Linux常⽤服务器构建-samba
  • 【Java】已解决java.lang.UnsupportedOperationException异常
  • 在ubuntu中恢复误删除的文件
  • Sklearn中逻辑回归建模
  • 【ARM】MDK出现报错error: A\L3903U的解决方法
  • 0018__字体的kerning是什么意思
  • LORA: LOW-RANK ADAPTATION OF LARGE LANGUAGE MODELS
  • cmake、make、makefile、ninga的关系
  • StarRocks详解