Mybatis 动态Sql标签使用总结

一、前言

常用的动态sql标签包括 if、choose(when、otherwise)、trim(where、set)、foreach。

二、标签介绍

2.1、if 标签

1、动态拼接查询条件

select DISTINCT ksid as id,ksdm as cd , ksmc as na ,id_org ,1 as fg_active,kspydm as py FROMV_CIS_RO_USERWHERE 1=1<if test="orgId != null">AND id_org = #{orgId}</if><if test="userId != null">AND YHID = #{userId}</if><if test="id != null">AND ksid = #{id}</if><if test="search != null and  search != '' ">and  kspydm LIKE concat('%', concat(#{search}, '%'))</if>ORDER BY kspydm

2、动态选择不同的执行sql

根据输入参数unitType的不同情况来join不同的表查询结果集。

<select id="getAdjRatios" resultType="com.fp.epower.model.dto.PowerPredictAdjDto"><if test="unitType == null">SELECT a.*,b.date,b.status FROM power_forecast_adjust_data aLEFT JOIN power_forecast_adjust_info bON a.info_id = b.id</if><if test="unitType != null and unitType == 1">SELECT a.*,b.date,b.status,c.dispatch_name unitName FROM power_forecast_adjust_data aLEFT JOIN power_forecast_adjust_info bON a.info_id = b.idLEFT JOIN gen_set cON a.unit_id = c.id</if><if test="unitType != null and unitType == 2">SELECT a.*,b.date,b.status,c.abbreviation unitName FROM power_forecast_adjust_data aLEFT JOIN power_forecast_adjust_info bON a.info_id = b.idLEFT JOIN dic_power_plant_info cON a.unit_id = c.id</if><where><if test="status != null">b.status = #{status}</if><if test="unitType != null and unitType != 0">AND a.unit_type = #{unitType}</if><if test="date != null">AND b.date = #{date}</if></where></select>

2.2、choose(when、otherwise) 标签

如果拼接的查询条件存在多个分支,可以使用 choose(类似于switch关键字)

<select id="getAdjRatio" resultType="java.lang.String">SELECT ratio FROM power_forecast_adjust_data aLEFT JOIN power_forecast_adjust_info bON a.info_id = b.id<choose><when test="status != null and status != 0">b.`status` = #{status}</when><when test="unitType != null and unitType != 0">AND a.unit_type = #{unitType}</when><when test="unitId != null and unitId != ''">AND a.unit_id = #{unitId}</when><when test="date != null">AND b.date = #{date}</when><otherwise>b.`status` = 1</otherwise></choose></select>

2.3、trim(where、set) 标签

使用 trim 可以定义如何覆盖前缀或者后缀,可以定义where节点、set节点等在有多余字符存在的情况下的前后缀覆盖策略。

<select id="selectUsers" resultType="com.example.User">SELECT *FROM user<trim prefix="WHERE" prefixOverrides="AND | OR "><if test="name != null">AND name = #{name}</if><if test="age != null">AND age = #{age}</if><if test="gender != null">AND gender = #{gender}</if></trim>
</select>

说明:

在语句的FROM子句后面使用了标签来处理WHERE子句中的条件。下面是对标签的几个常用属性的解释:

1、prefix:指定在元素内容之前添加的字符串,这里是"WHERE",即在WHERE子句之前添加"WHERE"关键字。

2、prefixOverrides:指定需要从元素内容中移除的字符串,多个字符串使用"|"隔开,这里移除了以"AND"或"OR"开头的内容。

在 trim 标签中,根据条件判断使用 if 标签来动态生成SQL语句的WHERE子句。if 标签的test属性用于判断条件是否成立,如果条件成立,则会将 if 标签中的内容添加到生成的SQL语句中。

最终生成的SQL语句将会根据传入的参数动态生成,只在满足条件的情况下添加WHERE子句的条件,如下所示:

SELECT * FROM user WHERE name = #{name} AND age = #{age}

注意,由于使用了 trim 标签,只有在满足条件的情况下才会添加WHERE关键字和相应的条件。

2.4、foreach 标签

1、foreach元素的属性

item: 集合元素迭代时的别名称,该参数为必选项,如果遍历的对象是map,则item为val;

index: 在list、array中,index为元素的序号索引。但是在Map中,index为遍历元素的key值,该参数为可选项;

open: 遍历集合时的开始符号,通常与close=")"搭配使用。使用场景IN(),values()时,该参数为可选项;

separator: 元素之间的分隔符,类比在IN()的时候,separator=“,”,最终所有遍历的元素将会以设定的(,)逗号符号隔开,该参数为可选项;

close: 遍历集合时的结束符号,通常与open="("搭配使用,该参数为可选项;

2、collection属性值的三种情况

2.1、如果传入的参数类型为list时: collection的默认属性值为list,同样可以使用@Param注解自定义name;

2.2、如果传入的参数类型为array时: collection的默认属性值为array,同样可以使用@Param注解自定义name;

2.3、如果传入的参数类型为Map时: collection的属性值可为三种情况:1.遍历map.keys;2.遍历map.values;3.遍历map.entrySet();

3、代码示例

<select id="getAdjRatio" resultType="java.lang.String">SELECT ratio FROM power_forecast_adjust_data aLEFT JOIN power_forecast_adjust_info bON a.info_id = b.id<where>id IN <foreach collection="ids" item="id" open="(" close=")" separator=",">#{id}</foreach></where>
</select>

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

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

相关文章

数据结构 - 链表详解(二)—— 带头双向循环链表

链表的介绍 链表的结构一共有八种&#xff1a;带头单向循环链表、带头单向非循环链表、带头双向循环链表、带头双向非循环链表、无头单向循环链表、无头单向非循环链表、无头双向循环链表、无头双向非循环链表。 今天我们来详解带头双向循环链表 带头双向循环链表是一种数据结…

Flutter开发好用插件url_launcher详解-启动 URL

文章目录 url_launcher介绍安装用法错误处理自定义行为其他功能 url_launcher介绍 url_launcher 是一个 Flutter 插件&#xff0c;用于启动 URL。它支持网络、电话、短信和电子邮件方案。您可以使用它从您的 Flutter 应用程序中打开网站、拨打号码、发送短信或撰写电子邮件。 …

javaSE (七):异常

目录 一、Java 异常概述 1.异常概念 2.异常的抛出机制 3.如何对待异常 二、 java异常体系结构 1.Throwable 2. Throwable分类 三、常见的异常 1.Error 2.异常--运行时异常 四、异常处理 1.try 2.catch 3.finally 4.throws 5.throw 五、运行期异常和编译期异常…

commvault学习(6):备份oracle(包括oracle的安装)

1.环境 CS、MA&#xff1a;一台windows server2012 客户端&#xff1a;2台安装了oracle11g的windows server2008 1.1 windows server2008安装oracle11g &#xff08;1&#xff09;右击安装包内的setup&#xff0c;以管理员方式运行 &#xff08;2&#xff09;取消勾选接收安…

仿真-Carla初识-安装

仿真方面研究,希望掌握仿真技术 目录 前言1. Carla基本架构2.Carla安装2.1 Pre-comiled版本2.1.1 安装要求2.1.2 安装前言 学习参考文档: 1.小飞自动驾驶系列分享 1. Carla基本架构 Client-Server的交互形式:Carla主要分为Server与Client两个模块,Server端用来建立这个仿…

echarts柱形图实现2.5D

思路&#xff1a;使用markpoint option {title: {text: Rainfall vs Evaporation,subtext: Fake Data},tooltip: {trigger: axis},legend: {data: [Rainfall, Evaporation]},toolbox: {show: true,feature: {dataView: { show: true, readOnly: false },magicType: { show: t…

51单片机入门_江协科技_27~28_OB记录的自学笔记_AT24C02数据存储秒表

27. AT24C02(I2C总线) 27.1. 存储器介绍 27.2. 存储器简化模型介绍&#xff0c;存储原理 27.3. AT24C02介绍 •AT24C02是一种可以实现掉电不丢失的存储器&#xff0c;可用于保存单片机运行时想要永久保存的数据信息 •存储介质&#xff1a;E2PROM •通讯接口&#xff1a;I2…

Python基础:【习题系列】判断题(三)

在Python中&#xff0c;列表推导可以用来创建新的列表。 答案&#xff1a;对 Python中使用!操作符来检查两个值是否不相等。 答案&#xff1a;对 Python中的类定义中必须包含至少一个方法。 答案&#xff1a;错 nonlocal关键字用于在函数或其他作用域内访问外部&#xff08;…

【JS基础】1.函数、匿名函数、回调函数、IIFE(立即执行函数)

【JS基础】1.函数、匿名函数、回调函数、IIFE(立即执行函数) 1. 认识函数 函数到底是什么&#xff1f; 函数其实就是某段代码的封装&#xff0c;这段代码帮助我们完成某一下功能JS引擎中有一些已经提供的函数我们也可以编写属于自己的函数 函数使用的步骤 声明函数&#xff1…

十大经典排序算法之插入排序。

插入排序 (Insertion Sort) ​ 插入排序&#xff08;Insertion Sort&#xff09;是一种简单直观的排序算法&#xff0c;它的基本思想是逐步构建最终的排序列表&#xff0c;每次将一个未排序的元素插入到已排序的部分的适当位置。 插入排序的基本步骤如下&#xff1a; 首先&a…

第十五届蓝桥杯省赛第二场C/C++B组E题【遗迹】题解

解题思路 错解 贪心&#xff1a;每次都移动至当前最近的对应方块上。 反例&#xff1a; s s s abxac t t t abac 贪心结果&#xff08;下标&#xff09; 0 → 1 → 0 → 4 0 \rightarrow 1 \rightarrow 0 \rightarrow 4 0→1→0→4&#xff0c;答案为 5 5 5。 正确结…

仿真-Carla初识-运行

目录 0.简介1.导入地图AdditionalMaps2.Carla运行 0.简介 carla-github下载 python是通过ip127.0.0.1&#xff0c;port 2000与Carla进行本地通讯的&#xff08;脚本与CarlaUE4.exe在同一台电脑&#xff09;&#xff0c;下面可能是大家可能会遇到的问题&#xff1b; 代码中端口…

VMware配置centos虚拟机实现内网互通

VMware配置centos虚拟机实现内网互通 一、安装无桌面模式 环境说明&#xff1a; VMWare版本&#xff1a;VMware Workstation 17 Pro Centos版本&#xff1a;CentOS-7.9-x86_64-DVD-2009.iso 一键下载本文资源包 1. 安装虚拟机 下面是创建具体步骤,其中需要注意的是&#xff1…

说说2024年暑期三下乡社会实践工作新闻投稿经验

作为一名在校大学生,我有幸自去年起参与学院组织的暑期大学生三下乡社会实践团活动。这项活动不仅是我们深入基层、服务社会的重要平台,也是展现当代大学生风采、传递青春正能量的有效途径。然而,如何将这些生动鲜活的实践故事、感人至深的瞬间传播出去,让更多人了解并受到启发…

LeetCode54. 螺旋矩阵

LeetCode54.螺旋矩阵 题解思路 代码 class Solution { public:vector<int> spiralOrder(vector<vector<int>>& matrix) {vector<int> res;int n matrix.size();// 行int m matrix[0].size(); // 列vector<vector<bool>> st(n, v…

懂技术不代表懂互联网

作为一个技术开发者&#xff0c;也就是程序员&#xff0c;个人一直认为自己是一个互联网从业者&#xff0c;也认为自己懂互联网。但是&#xff0c;直到今天突然才发现&#xff0c;自己根本不懂互联网&#xff0c;自己认为的懂互联网只是从技术人员的角度理解互联网&#xff0c;…

【JAVA】PO、VO、DAO、BO、DTO、POJO你分得清吗?

在Java开发中&#xff0c;PO、VO、DAO、BO、DTO、POJO这些词汇是比较常见的&#xff0c;每个术语都有其特定的含义和用途。下面是它们的具体区别&#xff1a; 名称简要概况用途和特定PO (Persistence Object) 持…

2024.4.25力扣每日一题——总行驶距离

2024.4.25 题目来源我的题解方法一 模拟 题目来源 力扣每日一题&#xff1b;题序&#xff1a;2739 我的题解 方法一 模拟 当mainTank还剩5升及以上的油&#xff0c;直接一次性减5升&#xff0c;距离加50&#xff0c;然后看additionalTank是否还有油&#xff0c;若有减1&…

数据结构与算法学习笔记五--串(C++)

目录 前言 一、定义 二、串的表示和实现 1.定长顺序存储表示 1.定义 2.串拼接 3.求子串 4.完整代码 2.堆分配存储表示 1.定义 2.求串长 3.串比较 4.清空s串&#xff0c;释放空间 5.串拼接 6.求子串 7.完整代码 3.串的块链存储表示 1.定义 2.生成串 3.生成串…

revit\navisworks各种安装问题

You have entered a nonvalid serial number &#xff0c;怎么都不给你一个机会输出序列号&#xff0c;怎么办&#xff1f; step1: C:\Program Files (x86)\Common Files\Autodesk Shared\AdskLicensing目录下找到uninstall.exe&#xff0c;右键管理员模式运行&#xff0c;会…