MyBatis的动态SQL---组合条件查询与传递集合和数组(超详细)

本文主要是介绍MyBatis的动态SQL---组合条件查询与传递集合和数组(超详细),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MyBatis的动态SQL—组合条件查询与传递集合和数组(超详细)

文章目录

  • MyBatis的动态SQL---组合条件查询与传递集合和数组(超详细)
    • 一、 定义
    • 二、mybatis提供的几大标签
      • 1. if 标签
      • 2. choose、when和otherwise标签
      • 3. trim标签
      • 4. foreach标签
      • 5. set标签
      • 6.where标签
      • 7.bind标签
    • 三、组合条件查询问题
      • 1、编写SQL描述
      • 2、测试
      • 3、UserQueryVo的编写
    • 四、传递集合和数组的问题
      • 1、编写SQL描述
      • 2、编写测试

一、 定义

MyBatis 提供了强大的 动态 SQL 支持,使得开发者可以根据不同的查询条件动态生成 SQL 语句。通过动态 SQL,可以避免手写复杂的拼接逻辑 。

二、mybatis提供的几大标签

1. if 标签

<if> 标签用于根据条件动态拼接 SQL 语句。如果条件成立,则将对应的 SQL 片段加入最终的 SQL 中。

<select id="getUser" resultType="User">SELECT * FROM users<where><if test="id != null">AND id = #{id}</if><if test="name != null">AND name = #{name}</if></where>
</select>
  • 解释<if> 标签会自动处理 SQL 中的 ANDOR,在没有条件时不会产生多余的关键字。
  • 注意test 表达式可以判断参数是否为空、大小比较等。

2. choose、when和otherwise标签

这组标签类似于 Java 中的 switch 语句,用于从多个条件中选择一个执行。

<select id="getUserByCondition" resultType="User">SELECT * FROM users<where><choose><when test="id != null">AND id = #{id}</when><when test="name != null">AND name = #{name}</when><otherwise>AND status = 'active'</otherwise></choose></where>
</select>

解释:如果 id 存在,则优先匹配第一个 <when>,否则匹配 name,最后如果都不满足,则使用 <otherwise> 的默认条件。

3. trim标签

<trim> 标签用于自定义 SQL 片段的修饰符,比如去除多余的逗号或 AND。它可以在生成的 SQL 语句前后添加或删除内容。

<update id="updateUser">UPDATE users<set><trim suffixOverrides=","><if test="name != null">name = #{name},</if><if test="email != null">email = #{email},</if></trim></set>WHERE id = #{id}
</update>

解释<trim> 标签的 suffixOverrides="," 表示去除生成的 SQL 语句末尾的逗号。

4. foreach标签

<foreach> 标签用于遍历集合(如 ListSetArray 等)并动态生成 SQL 语句,通常用于批量操作或 IN 查询。

<select id="getUsersByIds" resultType="User">SELECT * FROM users WHERE id IN<foreach item="id" index="index" collection="idList" open="(" separator="," close=")">#{id}</foreach>
</select>

解释collection 指的是传递的集合,item 是集合中的每个元素,openclose 分别表示 SQL 语句的开头和结尾,separator 是元素之间的分隔符 。

5. set标签

<set> 标签常用于 UPDATE 语句,自动处理多个 SET 子句,并去掉末尾多余的逗号。

<update id="updateUser">UPDATE users<set><if test="name != null">name = #{name},</if><if test="email != null">email = #{email},</if></set>WHERE id = #{id}
</update>

解释<set> 标签自动去掉最后的逗号,生成合法的 SQL 语句。

6.where标签

<where> 标签用于处理 WHERE 条件,它可以智能地添加或删除多余的 ANDOR,确保生成的 SQL 语句格式正确。

<select id="getUserByDynamicConditions" resultType="User">SELECT * FROM users<where><if test="id != null">id = #{id}</if><if test="name != null">AND name = #{name}</if></where>
</select>

解释:如果 idname 为空,<where> 标签会自动去除多余的 AND,保持 SQL 语句的正确性。

7.bind标签

<bind> 标签用于创建临时变量,方便在复杂的动态 SQL 中使用。通常用于处理需要预处理的表达式或格式化参数。

<select id="getUserByNamePattern" resultType="User"><bind name="pattern" value="'%' + name + '%'"/>SELECT * FROM users WHERE name LIKE #{pattern}
</select>

解释<bind> 标签可以将变量 name 的值进行处理,生成一个包含通配符 % 的字符串,然后在 LIKE 查询中使用。

三、组合条件查询问题

组合条件查询的问题
比如:我可以通过id查询 也可以通过 用户名 还可以通过密码查询 也可以随机组合查询 如果都不传递参数那么就查询所有数据

1、编写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.qfedu.edu.dynamicsql.UserMapper"><!--    这里是研究组合条件查询的问题--><select id="findUserByCondition" parameterType="user" resultType="user">select * from t_user where 1=1<include refid="condition"></include></select><!--    组合条件查询的第二种方式where标签会把第一个满足条件的的and给去掉--><select id="findUserByCondition2" parameterType="user" resultType="user">select * from t_user<where><include refid="condition"></include></where></select><!--    抽取这个SQL片段--><sql id="condition"><if test="userId!=null">and userId=#{userId}</if><if test="username!=null and username!=''">and username=#{username}</if><if test="password!=null and password!=''">and password=#{password}</if></sql><!--    组合条件查询用户数据prefixOverrides:覆盖第一个and 简单的说满足条件的第一个and去掉suffixOverrides="":覆盖最后一个啥prefix="":添加一个前缀suffix="":添加一个什么后缀--><select id="findUserByCondition3" parameterType="com.qfedu.edu.vo.UserQueryVo" resultType="user">select * from t_user<if test="user!=null">where<trim prefixOverrides="and" ><if test="user.userId!=null">and userId=#{user.userId}</if><if test="user.username!=null and user.username!=''">and username=#{user.username}</if><if test="user.password!=null and user.password!=''">and password=#{user.password}</if></trim></if></select>
</mapper>

2、测试

package com.qfedu.edu.dynamicsql;import com.qfedu.edu.pojo.User;
import com.qfedu.edu.vo.UserQueryVo;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;import java.io.IOException;
import java.util.List;import static com.qfedu.edu.utils.MyBatisUtilsMax.close;
import static com.qfedu.edu.utils.MyBatisUtilsMax.getSqlSession;/*** @author xiaobobo* @title: Test001* @projectName cd-java-fy-2401-framwork-demo* @description: TODO* @date 2024/9/2  15:24*/
public class Test001 {@Testpublic void testFindUserByCondition() throws IOException {SqlSession sqlSession = getSqlSession();//获取接口对象UserMapper userMapper = sqlSession.getMapper(UserMapper.class);//        UserQueryVo userQueryVo = new UserQueryVo();User user = new User();user.setUserId(123);user.setUsername("小波波");//        userQueryVo.setUser(null);//再调用这个接口中的方法List<User> userList = userMapper.findUserByCondition(user);System.out.println("返回来的这个用户对象是:" + userList);close();}
}

3、UserQueryVo的编写

@Data
@AllArgsConstructor
@NoArgsConstructor
public class UserQueryVo {//这里维护这个User对象private User user;
}

四、传递集合和数组的问题

传递集合和数组的问题
传递集合的时候 这个类型就是list
这个集合的名字 也是 list
item:这个是每一次遍历出来的数据
open:SQL语句以什么开始
close:SQL语句以什么结束
separator:遍历出来的值与之之间使用,分割

1、编写SQL描述

<!--    下面研究传递集合和数组的问题传递集合的时候 这个类型就是list这个集合的名字 也是 listitem:这个是每一次遍历出来的数据open:SQL语句以什么开始close:SQL语句以什么结束separator:遍历出来的值与之之间使用,分割
--><select id="listByIds1" parameterType="list" resultType="user">select * from t_user<foreach collection="list" item="userId" open="where userId in(" close=")" separator=",">#{userId}</foreach></select><!--    这个研究的是传递数组类型的参数传递数组类型参数的时候 那么这个集合的名字叫做 array--><select id="listByIds2" parameterType="integer[]" resultType="user">select * from t_user<foreach collection="array" item="userId" open="where userId in(" close=")" separator=",">#{userId}</foreach></select>

2、编写测试

@Testpublic void testListByIds1() throws IOException {SqlSession sqlSession = getSqlSession();//获取接口对象UserMapper userMapper = sqlSession.getMapper(UserMapper.class);List<Integer> ids=new ArrayList<Integer>();ids.add(1);ids.add(2);ids.add(3);//再调用这个接口中的方法List<User> userList = userMapper.listByIds1(ids);System.out.println("返回来的这个用户对象是:" + userList);close();}@Testpublic void testListByIds2() throws IOException {SqlSession sqlSession = getSqlSession();//获取接口对象UserMapper userMapper = sqlSession.getMapper(UserMapper.class);Integer[] ids={1,2,3,4};//再调用这个接口中的方法List<User> userList = userMapper.listByIds2(ids);System.out.println("返回来的这个用户对象是:" + userList);close();}

这篇关于MyBatis的动态SQL---组合条件查询与传递集合和数组(超详细)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

MySQL中比较运算符的具体使用

《MySQL中比较运算符的具体使用》本文介绍了SQL中常用的符号类型和非符号类型运算符,符号类型运算符包括等于(=)、安全等于(=)、不等于(/!=)、大小比较(,=,,=)等,感兴趣的可以了解一下... 目录符号类型运算符1. 等于运算符=2. 安全等于运算符<=>3. 不等于运算符<>或!=4. 小于运

虚拟机Centos7安装MySQL数据库实践

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net... 目录安装mysql数据库下载wget命令下载MySQL安装包安装MySQL安装MySQL服务安装完成

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

MySQL逻辑删除与唯一索引冲突解决方案

《MySQL逻辑删除与唯一索引冲突解决方案》本文探讨MySQL逻辑删除与唯一索引冲突问题,提出四种解决方案:复合索引+时间戳、修改唯一字段、历史表、业务层校验,推荐方案1和方案3,适用于不同场景,感兴... 目录问题背景问题复现解决方案解决方案1.复合唯一索引 + 时间戳删除字段解决方案2:删除后修改唯一字

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤

MySQL 主从复制部署及验证(示例详解)

《MySQL主从复制部署及验证(示例详解)》本文介绍MySQL主从复制部署步骤及学校管理数据库创建脚本,包含表结构设计、示例数据插入和查询语句,用于验证主从同步功能,感兴趣的朋友一起看看吧... 目录mysql 主从复制部署指南部署步骤1.环境准备2. 主服务器配置3. 创建复制用户4. 获取主服务器状态5

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

Windows环境下解决Matplotlib中文字体显示问题的详细教程

《Windows环境下解决Matplotlib中文字体显示问题的详细教程》本文详细介绍了在Windows下解决Matplotlib中文显示问题的方法,包括安装字体、更新缓存、配置文件设置及编码調整,并... 目录引言问题分析解决方案详解1. 检查系统已安装字体2. 手动添加中文字体(以SimHei为例)步骤

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更