Java MyBatis动态SQL

article/2025/8/22 9:06:06

🧭MyBatis学习
🎉 内容回顾
Java MyBatis的介绍及其执行原理
Java MyBatis配置详解
Java Mybatis中使用Junit进行测试_程序员必备
Java MyBatis的使用
📢今天我们进行 Java MyBatis动态SQL 的学习,感谢你的阅读,内容若有不当之处,希望大家多多指正,一起进步!!!
♨️如果觉得博主文章还不错,可以👍三连支持⭐一下哦😀

文章目录

  • 🍀Java MyBatis动态SQL
    • ☘️一、动态SQL
    • ☘️二、标签使用
      • 🌵if标签
      • 🌵where标签
      • 🌵trim便签
      • 🌵foreach标签
      • 🌵bind标签

🍀Java MyBatis动态SQL

☘️一、动态SQL

mybatis中特征之一支持动态SQL,以标签的形式动态编写SQL,根据业务逻辑来动态的进行SQL拼接功能。mybatis提供的9种动态SQL标签trimifwheresetforeachchoosewhenotherwisebind

执行原理:使用OGNL从SQL参数对象中计算表达式的值,根据表达式的值动态拼接SQL,以此完成动态SQL的功能。

动态SQL通常放在where子句的一部分中,常用于查询 插入 更新等操作。

☘️二、标签使用

🌵if标签

场景: 根据姓名、性别、姓名和性别的查询相应的数据

StudentMapper

List<Student> selectStudentBySnameOrSsex(Student student);

StudentMapper.xml

因为考虑到每个if体中都含有and,当为真时会增加一个and,所以在SQL语句where后用 1 = 1 巧妙的避开了这种尴尬。

<select id="selectStudentBySnameOrSsex" parameterType="student" resultMap="studentMap">select * from student where 1 = 1<if test="name != null">and Sname = #{name}</if><if test="Ssex != null">and Ssex = #{Ssex}</if>
</select>

if表达式中判断参数是否传递,test属性:该属性必填,为true或者false,test使用OGNL表达式处理,返回为true则进入if标签中的SQL,返回为false则不会进入标签中。

测试

传递两个参数
在这里插入图片描述
传递一个参数
在这里插入图片描述
不传递参数
在这里插入图片描述

🌵where标签

where标签:如果该标签包含的元素有返回值,就插入一个where,如果where后面的字符串是以and或者or开头的,就将他们剔除。

<select id="selectStudentBySnameOrSsex" parameterType="student" resultMap="studentMap">select * from student<where><if test="name != null">and Sname = #{name}</if><if test="Ssex != null">and Ssex = #{Ssex}</if></where></select>

执行结果:
select * from student WHERE Sname = ? and Ssex = ? //传递两个参数
select * from student WHERE Sname = ? //只传递name
select * from student WHERE Ssex = ? //只传递sex
select * from student //不传递参数

where表达式一般和if表达式一块使用,如果条件一个都不满足,则不拼接where条件,如果有一个或者多个表达式成立,where会直接拼接在SQL上,并且紧随where的表达式的and/or会忽略掉。

🌵trim便签

MyBatis提供trim标签一般适用于取出SQL语句中多余的and关键字,逗号,或者给SQL语句拼接”where“、”Set”以及values等,可用于选择性插入,更新,删除或者条件查询等操作,where和set标签都可以通过trim标签来实现

trim标签存在属性

属性描述
prefix给sql语句拼接的前缀
suffix给sql语句拼接的后缀
prefixOverrides去除sql语句前面的关键字或者字符,该关键字或者字符由prefixOverrides属性指定,假设该属性指定为“AND”,当sql语句的开头为“AND”,trim标签会去除“AND”
suffixOverrides去除sql语句后面的关键字或者字符, 该关键字或者字符由suffixOverrides属性指定
<select id="selectStudentBySnameOrSsex" parameterType="student" resultMap="studentMap">select * from student<trim prefix="where" prefixOverrides="and"><if test="name != null">and Sname = #{name}</if><if test="Ssex != null">and Ssex = #{Ssex}</if></trim>
</select>

🌵foreach标签

适用于批量操作

foreach表达式
collection属性: 必填,指定参数入参类型 列表(list) 、数组(array)、HashMap(map)
item属性:起名字,给集合中单个元素起名称
open属性:开始字符串
close属性:结束字符串
separator属性:分割符
index属性:索引的属性名,在集合数组下值为当前的索引值

场景:通过一批id来查询用户 select * from student where SID in(1,2,3,4,5);

StudentMapper

List<Student> batchQureyStudent(List<Integer> sid);

StudentMapper.xml

<select id="batchQureyStudent" resultType="int" resultMap="studentMap">select * from student where SID in<foreach collection="list" item="sid" open="(" close=")" separator=",">#{sid}</foreach>
</select>

执行结果
在这里插入图片描述

🌵bind标签

bind标签适合模糊查询,bind表达式中参数必须是具有getter方法,底层是通过OGNL表达式来进行解析,该表达式通过属性的getter进行获取值。

场景:查询student表中名字带有L的学生信息。select * from student where Sname like “%L%”;

StudentMapper

<select id="selectStudentByName" parameterType="string" resultMap="studentMap"><bind name="n" value="'%'+name+'%'"/>select * from student where Sname like #{n}
</select>

执行结果
在这里插入图片描述
解读:

name起名字,通过name找到value值。
在这里插入图片描述


http://chatgpt.dhexx.cn/article/jLjO23qY.shtml

相关文章

mysql动态SQL用法

顾名思义“动态”SQL就是不固定的SQL&#xff0c;根据不同的条件把SQL语句进行拼接&#xff0c;来实现对数据库更加精准的操作。可以通过配置文件或者注解的形式实现&#xff0c;多用于多条件联查。 xml版&#xff08;配置文件&#xff09;&#xff1a; xml版的动态SQL 接…

动态SQL标签

所谓的动态SQL&#xff0c;本职还是SQL语句&#xff0c;只是可以在SQL层面&#xff0c;去执行一个逻辑代码 动态SQL就是在拼接SQL语句&#xff0c;我们只要保证SQL的正确性&#xff0c;按照SQL的格式&#xff0c;去排列组合。 建议&#xff1a; 先在MySQL中写出完整的SQL&am…

MyBatis动态SQL

文章目录 前言一、\<if\>标签二、\<where\>标签三、\<trim\>标签四、\<set\>标签五、\<foreach\>标签五、\<sql\>标签 与 \<include\>标签 前言 动态sql是Mybatis的强大功能特性之一&#xff0c;能够完成不同条件下的sql拼接 以上…

动态SQL

动态SQL 在项目开发中&#xff0c;动态SQL可以解决很多不确定因素导致的SQL语句不同的问题。动态SQL可以简单高效的进行编码。在接下来的案例中进行认识和学习动态SQL。 动态SQL只是在原有的SQL语句中进行细微修改。案例贴合实际&#xff0c;编码简单易懂 文章目录 动态SQL一、…

动态 SQL

文章目录 一、学习目的二、动态 SQL 中的元素三、条件查询操作四、更新操作五、复杂查询操作1.foreach 元素中的属性2.foreach 元素迭代数组3.foreach 元素迭代 List4.foreach 元素迭代 Map 一、学习目的 在实际项目的开发中&#xff0c;开发人员在使用 JDBC 或其他持久层框架…

第3章 动态SQL

目录/Contents 第3章 动态SQL学习目标掌握MyBatis中动态SQL元素的使用掌握MyBatis的条件查询操作掌握MyBatis的更新操作掌握MyBatis的复杂查询操作 学习内容1 动态SQL中的元素1.1 使用动态SQL的好处1.2 动态SQL常用元素 2 条件查询操作2.1 \<if>元素2.2 \<choose>、…

Mybatis的特性详解——动态SQL

Mybatis的特性详解——动态SQL 前言一、动态sql的元素1.MyBatis if标签&#xff1a;条件判断2.MyBatis choose、when和otherwise标签3.MyBatis where标签4.MyBatis set标签5.MyBatis foreach标签6.MyBatis bind标签7.MyBatis trim标签仰天大笑出门去&#xff0c;我辈岂是蓬蒿人…

Java编程基础八股文(背诵版)

Java语言具有哪些特点&#xff1f; Java为纯面向对象的语言。它能够直接反应现实生活中的对象。 具有平台无关性。java利用Java虚拟机运行字节码&#xff0c;无论是在Windows、Linux还是MacOS等其它平台对Java程序进行编译&#xff0c;编译后的程序可在其它平台运行。 Java为…

Java编程基础篇

目录 计算机、程序和Java概述计算机组成 基本程序设计标识符数值数据类型格式化控制台输出输入输出重定向输入重定向输出重定向输入输出重定向方法重载变量的范围 数组声明数组变量创建数组初始化数组可边长参数二维数组静态变量、常量和方法静态变量 限定字符串StringBuilder和…

Java 基础编程入门

一、什么是Java Java是一种编程语言二、应用场景 非windows平台下互联网环境的开发首选三、Java语言特点 1、应用面广 2、简单易学(相对于C/C) 3、面向对象(更符合我们看待事物的特点) 4、跨平台(一处编译&#xff0c;处处运行) 5、多线程(提升系统性能) 单线…

JAVA的编程基础(上)

1. JAVA的基本语法 1.1 注释 单行注释&#xff1a;// 多行注释&#xff1a;/* */ 文档注释&#xff1a;/** */ 注意&#xff1a;单行注释可以嵌套&#xff0c;多行注释和文档注释不可以嵌套 1.2 关键字 含义&#xff1a;在编程语言中&#xff0c;已经被赋予一些特殊含义…

Java编程基础(1)

1.Java基本语法 &#xff08;1&#xff09;Java程序的基本格式&#xff1a; 修饰符 class 类名 { 程序代码 } 如果Java程序要运行&#xff0c;则必须要有main方法&#xff0c;main方法是程序运行的入口 格式&#xff1a; 修饰符 class 类名{ public static void main&…

Java编程基础之网络编程

网络编程 文章目录 网络编程概述C/S和B/S网络通信协议网络编程要素 IP类UDP协议数据传输发送端接收端udp数据传输丢失问题 TCP概述Socket客户端ServerSocket服务端Socket**服务器代码**客户端代码 文件上传实现客户端服务端多线程版 概述 C/S和B/S 网络通信协议 协议:protoco…

java编程基础(一)二进制

文章目录 二进制面试题bit 和 bytejava 中的 byte 类型java 中 byte 类型表示正数&#xff1a;java 中 byte 类型表示负数&#xff1a; 四种整数类型的最小和最大值二进制和十进制的互转练一练java 代码中直接写二进制字面值代码仓库 二进制 对于任何已知类型的传统计算机而言…

Java 基础

Java 基础知识点整理 Java 语言是一种优秀的编程语言&#xff0c;由 C 语言、C 语言发展而来。Java 语言提供了一些有效的新特性&#xff0c;使得使用 Java 比 C 更容易写出“无错代码”。 Java特性和优点 面向对象编程的思想&#xff0c;更简单有效&#xff0c;Java 省略了 …

Java编程基础②

Java编程基础 Java中的注释Java中的标识符Java中的关键字Java中的常量常量类型定义常量 java中的变量变量的定义及其数据类型变量的类型转换变量的作用域 java运算符算术运算符赋值运算符比较运算符逻辑运算符位运算符运算符的优先级 java流程控制语句if条件语句switch条件语句…

第二章 Java编程基础

第二章 Java编程基础 目录 一&#xff0e; Java基本语法1. 基本格式2. 注释3. 标识符4. 关键字5. 常量 二&#xff0e; 变量1. 定义2. 数据类型3. 整数类型变量4. 浮点类型变量5. 字符类型变量6. 布尔类型变量7. 类型转换8. 自动提升9. 变量作用域 三&#xff0e; 运算符1. 算数…

【JAVA】1.编程基础

1.Java基本语法 JAVA基本格式&#xff1a; 修饰符 class 类名{ 程序代码 } public class java {public static void main(String[] args) {System.out.println("HelloWorld"); } public static void main(String[] args) {} &#xff08;对于初学者来说这个部分必…

第二章Java编程基础

一、填空题 1&#xff0e;Java程序代码必须放在一个类中&#xff0c;类使用class关键词定义。 2&#xff0e;Java中的注释有三类&#xff0c;分别是单行注释、多行注释、文档注释。 3&#xff0e;Java语言中&#xff0c;int类型所占存储空间为4个字节。 4&#xff0e;用于比…

Java基础 —— 编程入门

一、比特(bit)和字节(byte) 一个0或者一个1存储为一个比特(bit)&#xff0c;是计算机中最小的存储单位。计算机中是最基本的存储单元是字节(byte)。 每个字节由8个比特构成。 计算机就是一系列的电路开关。每个开关存在两种状态:关(off)和开(on)。如果电路是开的&#xff0c;它…