Mysql:重点且常用的 SQL 标签整理
目录
1 <resultMap> 标签
2 <sql> 标签
3 <where> 标签
4 <if> 标签
5 <trim> 标签
6 <foreach> 标签
7 <set> 标签
1 <resultMap> 标签
比如以下代码:
<resultMap type="SysCollege" id="SysCollegeResult"><result property="collegeId" column="college_id" /><result property="collegeCode" column="college_code" /><result property="collegeName" column="college_name" /><result property="collegeProvince" column="college_province" /><result property="collegeCity" column="college_city" /><result property="collegeDistrict" column="college_district" /><result property="collegePhone" column="college_phone" /><result property="collegeEmail" column="college_email" /><result property="collegeType" column="college_type" /><result property="collegeWebsite" column="college_website" /><result property="collegeIntroduced" column="college_introduced" /><result property="collegeLogo" column="college_logo" /><result property="collegeStudentNum" column="college_student_num" /><result property="collegeMajorNum" column="college_major_num" /><result property="collegeDeptNum" column="college_dept_num" /><result property="status" column="status" /></resultMap>
上述是
<resultMap>
标签来映射查询结果到SysCollege
对象的示例,该代码定义了一个名为SysCollegeResult
的结果映射,用于将查询结果中的列与SysCollege
对象的属性进行映射,这样定义了结果映射之后,当执行查询语句时,MyBatis 将会根据该映射将查询结果中的列值赋给SysCollege
对象的对应属性。
使用定义好的 <resultMap>标签:
2 <sql> 标签
比如以下代码:
<sql id="selectSysMajorVo">select major_id, major_code, major_name, major_type, major_degree, major_career from sys_major</sql>
这个就是定义好的sql代码块,可以在其它操作中直接使用,可以减少重复代码的编写,是非常方便的。
使用定义好的 <sql>标签:
3 <where> 标签
<where> 大多数情况下使用在,根据条件动态生成查询条件,生成 WHERE 子句
比如以下代码:
<select id="selectSysMajorList" parameterType="SysMajor" resultMap="SysMajorResult"><include refid="selectSysMajorVo"/><where> <if test="majorCode != null "> and major_code = #{majorCode}</if><if test="majorName != null and majorName != ''"> and major_name like concat('%', #{majorName}, '%')</if><if test="majorType != null and majorType != ''"> and major_type = #{majorType}</if><if test="majorDegree != null "> and major_degree = #{majorDegree}</if><if test="majorCareer != null and majorCareer != ''"> and major_career = #{majorCareer}</if></where></select>
比如:如果
majorCode
不为空,则生成and major_code = #{majorCode}
的查询条件,其它也是一样。
where和<where>标签有什么区别:
WHERE
关键字是静态的,需要手动编写每个查询条件,并使用连接符(例如 "AND" 或 "OR")来拼接条件。而<where>
标签是动态的,可以根据条件的存在与否来动态生成 WHERE 子句,并自动处理条件之间的连接符(比如上述代码中的and).
4 <if> 标签
<if>
标签通常用于在动态 SQL 中根据条件判断是否包含某部分 SQL 片段
比如跟上述<where>标签配合使用
5 <trim> 标签
<trim>
元素的作用是根据条件动态生成 SQL 语句的部分内容
比如以下代码:
<insert id="insertSysMajor" parameterType="SysMajor" useGeneratedKeys="true" keyProperty="majorId">insert into sys_major<trim prefix="(" suffix=")" suffixOverrides=","><if test="majorCode != null">major_code,</if><if test="majorName != null">major_name,</if><if test="majorType != null">major_type,</if><if test="majorDegree != null">major_degree,</if><if test="majorCareer != null">major_career,</if></trim><trim prefix="values (" suffix=")" suffixOverrides=","><if test="majorCode != null">#{majorCode},</if><if test="majorName != null">#{majorName},</if><if test="majorType != null">#{majorType},</if><if test="majorDegree != null">#{majorDegree},</if><if test="majorCareer != null">#{majorCareer},</if></trim></insert>
prefix="SET"
:指定生成的 SET 子句的前缀为 "SET"。
suffixOverrides=","
:指定如果 SET 子句的最后一个字符是逗号(,),则将其移除。
prefix="("
指定了插入语句的列名部分的前缀为左括号(
,suffix=")"
则指定了该部分的后缀为右括号)
,即(
和)
之间就是列名列表
当上述的值都不为空,生成的sql语句是:
insert into sys_major
(major_code, major_name, major_type, major_degree, major_career)
values
(#{majorCode}, #{majorName}, #{majorType}, #{majorDegree}, #{majorCareer})
在这段代码中,
useGeneratedKeys="true"
表示要从数据库中获取自动生成的主键值,keyProperty="majorId"
则指定了自动生成的主键值将赋给SysMajor
对象中的majorId
属性。如果执行插入操作成功,并且数据库返回了自动生成的主键值,MyBatis 会将该值赋给
majorId
属性,作为插入操作的返回值。因此,如果程序需要获取插入操作生成的主键值,则可以通过majorId
属性来获取。如果插入操作失败或者没有生成主键值,则majorId
属性的值不会改变。
6 <foreach> 标签
<foreach>
标签,用于遍历传入的数组
比如以下代码:实现批量删除!
<delete id="deleteSysMajorByMajorIds" parameterType="String">delete from sys_major where major_id in <foreach item="majorId" collection="array" open="(" separator="," close=")">#{majorId}</foreach></delete>
item="majorId"
:指定遍历过程中当前元素的别名为majorId
。
collection="array"
:指定要遍历的集合为array
,即传入的majorId
数组。
open="("
:指定循环开始时的字符为(
。
separator=","
:指定每个元素之间的分隔符为,
。
close=")"
:指定循环结束时的字符为)
。
#{majorId}
:表示当前遍历到的majorId
元素,会被替换为对应的值。
7 <set> 标签
<set>
标签用于定义一个包含更新字段内容的 SQL 片段
比如以下代码:
<update id="updateDictType" parameterType="SysDictType">update sys_dict_type<set><if test="dictName != null and dictName != ''">dict_name = #{dictName},</if><if test="dictType != null and dictType != ''">dict_type = #{dictType},</if><if test="status != null">status = #{status},</if><if test="remark != null">remark = #{remark},</if><if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if>update_time = sysdate()</set>where dict_id = #{dictId}</update>
update_time = sysdate()
表示更新update_time
字段为当前时间
相关文章:

Mysql:重点且常用的 SQL 标签整理
目录 1 <resultMap> 标签 2 <sql> 标签 3 <where> 标签 4 <if> 标签 5 <trim> 标签 6 <foreach> 标签 7 <set> 标签 1 <resultMap> 标签 比如以下代码: <resultMap type"SysCollege" id&qu…...

云锁防火墙编译安装nginx-plugin模块
一般情况下,当用户安装云锁的时候,云锁会自动适配nginx版本,使用我们已经预编译好的包含云锁模块的nginx备份并替换掉您当前系统中使用的nginx。卸载时,会将系统原始nginx文件替换回来。因此,云锁可保护使用nginx搭建的…...

【服务器数据恢复】服务器迁移数据时lun数据丢失的数据恢复案例
服务器数据恢复环境&服务器故障: 一台安装Windows操作系统的服务器。工作人员在迁移该服务器中数据时突然无法读取数据,服务器管理界面出现报错。经过检查发现服务器中一个lun的数据丢失。 服务器数据恢复过程: 1、将故障服务器中所有磁盘…...

6.4.2转换文件
6.4.2转换文件 利用Swf2VideoConverter2可以很方便地将Flash动画(*.swf)转换为其它的视频格式。 1.单击“添加”按钮,在弹出的下拉菜单中选择“添加文件”,在弹出的“Open Swf Files(打开Swf文件)”窗口中选择swf文件(如:那些花…...

智能驾驶新浪潮:SSD与UFS存储技术如何破浪前行?-UFS篇
如果说SSD是赛道上的超级跑车,那UFS更像是专为智能汽车定制的高性能轻量化赛车。UFS采用串行接口技术,像是闪电侠一样,将数据传输的速度推向新高,大幅缩短了系统启动时间和应用程序加载时间,这对追求即时反应的ADAS系统…...
TS 学习笔录(持续更新中)
TS学习笔录 1、TS 数据类型有哪些?2、元组是什么?3、union(联合类型)& Literal(字面量类型)?4、any 和 unknown 的区别?5、Object 对象类型?6、type 、interface 、 class 之间…...

RabbitMQ安装和使用
简介 RabbitMQ是一套开源(MPL)的消息队列服务软件,是由LShift提供的一个Advanced Message Queuing Protocol (AMQP) 的开源实现,由以高性能、健壮以及可伸缩性出名的Erlang写成。所有主要的编程语言均有与代理接口通讯的客户端库…...

使用pyechart创建折线图
import json from pyecharts.charts import Line from pyecharts import options# 首先使用文件打开数据 f_us open(Desktop/python/Project/数据可视化/美国.txt,r,encoding"UTF-8") f_rb open(Desktop/python/Project/数据可视化/日本.txt,r,encoding"UTF-8…...
Vue3+Ts:使用i18n实现国际化与全局动态下拉框框切换语言
Vue3Ts:使用i18n实现国际化与全局动态下拉框框切换语言 一、下载依赖:二、创建ts文件并配置main.ts三,如何使用1.在<template>中使用2.在setup中使用 四、全局下拉框动态切换 一、下载依赖: npm install vue-i18nnex二、创…...

多目标优化中常用的差分进化算法DE【2】
# 多目标优化中常用的进化算法 1、链接一 2、链接二 #后续继续补充多目标的差分进化算法MODE的应用 此链接介绍很详细,此处用来分享学习,后续有问题会继续进行补充。 如果你觉得不错,佛系随缘打赏,感谢,你的支持是…...

游卡:OceanBase在游戏核心业务的规模化降本实践
从 2023 年 9 月测试 OceanBase,到如今 3 个核心业务应用 OceanBase,国内最早卡牌游戏研发者之一的游卡仅用了两个月。是什么原因让游卡放弃游戏行业通用的 MySQL方案,选择升级至 OceanBase?杭州游卡网络技术有限公司(…...
LightDB - oracle_fdw 过滤条件下推增强【24.1】
LightDB - oracle_fdw 过滤条件下推增强【24.1】 1. 字符串比较下推1.1 示例 2. 隐式转换下推2.1 示例 3. nvl 和trim 下推3.1 示例 LightDB 在24.1版本对oracle_fdw 的where下推进行了增强,新增对如下两种情况进行下推: 字符串比较下推,如 …...

【计算机网络】HTTP协议以及简单的HTTP服务器实现
文章目录 一、HTTP协议1.认识URL2.urlencode和urldecode3.HTTP协议格式4.HTTP的方法5.HTTP的状态码6.HTTP常见Header7.重定向8.长连接9.会话保持10.基本工具 二、简单的HTTP服务器实现1.err.hpp2.log.hpp3.procotol.hpp4.Sock.hpp5.Util.hpp6.httpServer.hpp7.httpServer.cc8.总…...

04 SpringBoot整合Druid/MyBatis/事务/AOP+打包项目
整合Druid 项目结构: 引入依赖: <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaL…...
C++程序编译时的_GLIBCXX_USE_CXX11_ABI参数的值选择,适配昇腾Transformer推理加速库与LLM推理模型库
目录 2024/1/19日更新确定已安装G编译测试程序获取宏值安装对应的Transformer LLM推理模型库和Transformer推理加速库小结 2024/1/19日更新 具体使用cxx11abi0 还是cxx11abi1 可通过python命令查询 import torch torch.compiled_with_cxx11_abi()若返回True 则使用 cxx11abi1…...
什么是站群服务器?
网站群服务器是管理多个网站的强大工具,可以帮助站长轻松管理和维护多个网站,提高网站运营效率。在本文中,我们将讨论站点组服务器的优势,以及为什么它是网站管理员不可或缺的工具。 介绍站群服务器 网站群服务器是一个集中管理…...

《WebKit 技术内幕》之四(3): 资源加载和网络栈
3. 网络栈 3.1 WebKit的网络设施 WebKit的资源加载其实是交由各个移植来实现的,所以WebCore其实并没有什么特别的基础设施,每个移植的网络实现是非常不一样的。 从WebKit的代码结构中可以看出,网络部分代码的确比较少的,它们都在…...

vue3-模板引用
//1.调用ref函数 -> ref对象 const h1Ref ref(null) const comRef ref(null) //组件挂载完毕之后才能获取 onMounted(()>{console.log(h1Ref.value);console.log(comRef.value); })<div class"father"><!-- 通过ref标识绑定ref对象 --><h2 re…...

聚类模型评估指标
聚类模型评估指标-轮廓系数 计算样本i到同簇其它样本到平均距离ai,ai越小,说明样本i越应该被聚类到该簇(将ai称为样本i到簇内不相似度);计算样本i到其它某簇Cj的所有样本的平均距离bij,称为样本i与簇Cj的…...

测试 ASP.NET Core 中间件
正常情况下,中间件会在主程序入口统一进行实例化,这样如果想单独测试某一个中间件就很不方便,为了能测试单个中间件,可以使用 TestServer 单独测试。 这样便可以: 实例化只包含需要测试的组件的应用管道。发送自定义请…...
脑机新手指南(八):OpenBCI_GUI:从环境搭建到数据可视化(下)
一、数据处理与分析实战 (一)实时滤波与参数调整 基础滤波操作 60Hz 工频滤波:勾选界面右侧 “60Hz” 复选框,可有效抑制电网干扰(适用于北美地区,欧洲用户可调整为 50Hz)。 平滑处理&…...

理解 MCP 工作流:使用 Ollama 和 LangChain 构建本地 MCP 客户端
🌟 什么是 MCP? 模型控制协议 (MCP) 是一种创新的协议,旨在无缝连接 AI 模型与应用程序。 MCP 是一个开源协议,它标准化了我们的 LLM 应用程序连接所需工具和数据源并与之协作的方式。 可以把它想象成你的 AI 模型 和想要使用它…...
【学习笔记】深入理解Java虚拟机学习笔记——第4章 虚拟机性能监控,故障处理工具
第2章 虚拟机性能监控,故障处理工具 4.1 概述 略 4.2 基础故障处理工具 4.2.1 jps:虚拟机进程状况工具 命令:jps [options] [hostid] 功能:本地虚拟机进程显示进程ID(与ps相同),可同时显示主类&#x…...

JVM 内存结构 详解
内存结构 运行时数据区: Java虚拟机在运行Java程序过程中管理的内存区域。 程序计数器: 线程私有,程序控制流的指示器,分支、循环、跳转、异常处理、线程恢复等基础功能都依赖这个计数器完成。 每个线程都有一个程序计数…...

LINUX 69 FTP 客服管理系统 man 5 /etc/vsftpd/vsftpd.conf
FTP 客服管理系统 实现kefu123登录,不允许匿名访问,kefu只能访问/data/kefu目录,不能查看其他目录 创建账号密码 useradd kefu echo 123|passwd -stdin kefu [rootcode caozx26420]# echo 123|passwd --stdin kefu 更改用户 kefu 的密码…...

TSN交换机正在重构工业网络,PROFINET和EtherCAT会被取代吗?
在工业自动化持续演进的今天,通信网络的角色正变得愈发关键。 2025年6月6日,为期三天的华南国际工业博览会在深圳国际会展中心(宝安)圆满落幕。作为国内工业通信领域的技术型企业,光路科技(Fiberroad&…...

华为OD机试-最短木板长度-二分法(A卷,100分)
此题是一个最大化最小值的典型例题, 因为搜索范围是有界的,上界最大木板长度补充的全部木料长度,下界最小木板长度; 即left0,right10^6; 我们可以设置一个候选值x(mid),将木板的长度全部都补充到x,如果成功…...

【LeetCode】算法详解#6 ---除自身以外数组的乘积
1.题目介绍 给定一个整数数组 nums,返回 数组 answer ,其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。 题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在 32 位 整数范围内。 请 不要使用除法,且在 O…...

Ubuntu系统复制(U盘-电脑硬盘)
所需环境 电脑自带硬盘:1块 (1T) U盘1:Ubuntu系统引导盘(用于“U盘2”复制到“电脑自带硬盘”) U盘2:Ubuntu系统盘(1T,用于被复制) !!!建议“电脑…...

论文阅读:Matting by Generation
今天介绍一篇关于 matting 抠图的文章,抠图也算是计算机视觉里面非常经典的一个任务了。从早期的经典算法到如今的深度学习算法,已经有很多的工作和这个任务相关。这两年 diffusion 模型很火,大家又开始用 diffusion 模型做各种 CV 任务了&am…...