Mybatis值trim标签

article/2025/9/19 13:10:45

        Mybatis具有实现动态SQL的能力,使用这个特性免不了会用到trim这个标签,trim标签的功能简单来说就是自定义格式拼凑SQL语句。
        trim有4个属性:

prefix:表示在trim包裹的SQL前添加指定内容
suffix:表示在trim包裹的SQL末尾添加指定内容
prefixOverrides:表示去掉(覆盖)trim包裹的SQL的指定首部内容
suffixOverrides:表示去掉(覆盖)trim包裹的SQL的指定尾部内容

来看例子:
查找某个用户,通过名字和年龄

public User getUser(@Param("LastName") String lastName,@Param("age") Integer age,@Param("phone") String phone);

对应xml,先看首先想到的:

<select id="getUser" result="user">select * from user_tab where last_name=#{lastName} and age=#{age} and phone=#{phone}
</select>

执行时输出的SQL语句
在这里插入图片描述

  1. prefix
<select id="getUser" resultType="user">select * from user_tab <trim prefix="where">last_name=#{lastName} and age=#{age} and phone=#{phone}</trim>
</select>

输出同样SQL,这个就是prefix的效果
在这里插入图片描述

  1. prefixOverrides
    当然实际使用时查找条件都需要做一些判断,最基本的是否为null。
<select id="getUser" resultType="user">select * from user_tab <trim prefix="where"><if test="lastName != null">last_name=#{lastName}</if><if test="age != null">and age=#{age}</if><if test="phone != null">and phone=#{phone}</if></trim>
</select>

执行语句与上面一样,但是假如现在lastName参数为null,我们再看:

// 查询
User user = userMapper.getUser(null, 12,"120");

在这里插入图片描述
因为lastName为null,所以第一个if不成立里面的SQL语句不拼接,第二个if里面的and边紧跟在where后面了,语法错误,这是只要加上prefixOverride即可,把首个“and”去掉

<select id="getUser" resultType="user">select * from user_tab <trim prefix="where" prefixOverrides="and"><if test="lastName != null">last_name=#{lastName}</if><if test="age != null">and age=#{age}</if><if test="phone != null">and phone=#{phone}</if></trim>
</select>

在这里插入图片描述
如果是先要去掉and获取or,则必须这样写prefixOverrides=“and |or”,注意中间的空格。

  1. suffix、suffixOverrides
    上面查找,这里来看更新
// 根据id来更新
public void updateUser(@Param("user") User user);

对应的xml

<!--普通版-->
<update id="updateUser">update user_tabset last_name=#{lastName},age=#{age},phone=#{phone}where id=#{id}
</update>

使用suffix,并加上条件判断

<update id="updateUser"><trim suffix="where id=#{id}">update user_tabset<if test="lastName != null">last_name=#{lastName},</if><if test="age != null">age=#{age},</if><if test="phone != null">phone=#{phone}</if> </trim>
</update>

执行输出跟上面的普通版语句一样没问题,可以看到suffix的效果
在这里插入图片描述
同样的假如phone为null了,

// 更新
userMapper.updateUser(new User(2, "jack", 20, null));

在这里插入图片描述
因为最会一个if条件不成立,所以倒数第二个if里面的逗号在where的左侧语法错误,此时使用suffixOverrides即可

<update id="updateUser"><trim suffix="where id=#{id}" suffixOverrides=",">update user_tabset<if test="lastName != null">last_name=#{lastName},</if><if test="age != null">age=#{age},</if><if test="phone != null">phone=#{phone}</if> </trim>
</update>

再次执行输出,成功执行,这个就是suffixOverrides的作用
在这里插入图片描述

好了,这个就是trim标签即属性的基本介绍,具体怎么使用看实际情况,上面只是作为演示。


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

相关文章

MyBatis foreach标签

前面我们学习了如何使用 Mybatis if、where、trim 等动态语句来处理一些简单的查询操作。对于一些 SQL 语句中含有 in 条件&#xff0c;需要迭代条件集合来生成的情况&#xff0c;可以使用 foreach 来实现 SQL 条件的迭代。 Mybatis foreach 标签用于循环语句&#xff0c;它很…

mybatis常用标签

一.定义sql语句 1.select 标签 属性介绍: &#xff08;1&#xff09;id :唯一的标识符. &#xff08;2&#xff09;parameterType:传给此语句的参数的全路径名或别名 例:com.test.poso.User或user &#xff08;3&#xff09;resultType :语句返回值类型或别名。注意&#xff…

Mybatis中标签大全

文章目录 一、标签分类 二、标签总结 1. 基础SQL标签 1.1 查询select 1.2 增删改 1.3 其他基础标签 1.3.1 sql 标签 1.3.2 include 标签 1.3.3 if 标签 1.3.4 别名 2. collection与association标签 3. resultMap标签 4. foreach标签 5. where标签 6. set标签 7.…

jarsigner命令行签名打包

jarsigner签名&#xff0c;之前都是通过AS进行签名&#xff0c;通过这种方式也是可以签名的&#xff0c;需要提前把需要的东西准备好&#xff0c;现在把步骤记录在下面。&#xff08;下面的操作都是在jdk的路径下进行操作&#xff09; 1.首先准备Jdk的路径&#xff08;在androi…

jarsigner: 无法打开 jar 文件: tap_unsign.apk

flutter 的 android项目上线&#xff0c;我们在想应用宝发布应用时&#xff0c;需将key.jks文件放入应用宝的空白文件中&#xff0c;在cmd中执行 jarsigner -verbose -keystore key.jks -signedjar baoming.apk tap_unsign.apk name遇到如下报错 jarsigner: 无法打开 jar 文件…

apk重签名之jarsigner命令签名

apk的签名工作可以通过两种方式来完成&#xff1a; 1&#xff09;通过ADT提供的图形化界面完成apk签名&#xff1b;2&#xff09;完全通过DOS命令来完成apk签名 1&#xff09;准备工作 我比较喜欢第2&#xff09;种方式&#xff0c;所以下面将讲解如何通过命令的方式完成apk…

jarsigner签名

上线了3年多的项目,最近为了进行市场推广,在现在主流的vivo,oppo,华为及百度和阿里进行上传应用.因为有些市场是因为有抓取包的行为(比如在oppo应用市场,以前从未在oppo市场上传过应用,但是能在他的市场中搜索到,这就是因为在其他市场比如应用宝这些市场抓取过包),因此在诸如op…

使用jarsigner工具apk签名算法问题

为 -digestalg 选项指定的SHA1 算法 被视为存在安全风险。此算法将在未来的更新中被禁用。 为 -sigalg 选项指定的SHA1withRSA 算法被视为存在安全风险。此算法将在未来的更新中被禁用。 修改&#xff1a; 将 signcmd "%sjarsigner" -keystore "%s" -st…

Metasploit远程控制安卓手机,jarsigner(工具找不到)签名使用问题zipalign(工具)及解决方法

问题点&#xff1a; 1.kali linux2020.3版本&#xff0c;在使用msf生成安卓木马时远控手机&#xff0c;签名时需要3个工具&#xff0c;分别是keytool,jarsigner,zipalign,只提示有keytool工具&#xff0c;jarsigner和zipalign工具找不到. 2.在模拟器中成功&#xff0c;但很多…

使用jarsigner对APK签名

写在文章中之前&#xff1a;网上当前很多关于jarsigner对APK签名的讲法&#xff0c;但是有些讲的很粗糙&#xff0c;有些还在就在抄袭他人的文章&#xff0c;而自己却没有去验证是否正确 一、由于自己在工作中要用到jarsigner对apk进行最后的发布签名&#xff0c;所以自己也去…

Android 应用平台加固之后操作(apk重签名「zipalign」「apksigner」「jarsigner」) 操作环境:MacOS

Android 应用平台加固之后操作&#xff08;apk重签名&#xff09;「zipalign」「apksigner」「jarsigner」 前言运行环境对齐&#xff08;zipalign&#xff09;重签名 apksigner (推荐方法)重签名 jarsigner (v1打包)具体使用对齐「zipalign」出现 "Output file ......apk…

Windows平台 使用jarsigner对Apk签名

使用的是JDK自带的jarsigner工具来完成Apk签名 1) 首先找到你的Java Jdk中bin的路径&#xff1a;C:\Program Files\Java\jdk1.8.0_152\bin jarsigner简单使用说明 #jarsigner的命令格式&#xff1a; jarsigner -verbose -keystore [您的私钥存放路径] -signedjar [签名后文件存…

jarsigner和apksigner对apk/aab签名

1、查看签名文件的信息 工具目录&#xff1a;C:\Program Files\Java\jre1.8.0_331\bin keytool -list -v -keystore E:\test.jks输入该命令&#xff0c;然后输入密码&#xff0c;即可查看签名信息 2、签名工具 签名工具说明位置jarsignerJDK提供的针对jar包签名的通用工具…

Android jarsigner和apksigner签名apk(.jks)

前言 为了增加 Apk 的安全性&#xff0c;防止反编译&#xff0c;我们会对开发的 Apk 做签名处理&#xff0c;如果要上架应用商店&#xff0c;部分还会要求 Apk 必须加固后才能上架。另外存在一部分免费加固apk后会删除AndroidStudio打包的签名&#xff0c;需要我们重新签名&am…

jarsigner命令详解

用法&#xff1a;jarsigner [选项] jar 文件别名 jarsigner -verify [选项] jar 文件 [-keystore <url>] 密钥库位置[-storepass <口令>] 用于密钥库完整性的口令[-storetype <类型>] 密钥库类型[-keypass <口令>] …

Java的安装及‘jarsigner‘ 不是内部或外部命令解决方法(附jdk8下载链接)

安装JDK 下载JDK&#xff1a; 网盘地址 , 提取码&#xff1a;y5f3 双击安装程序 一直点击下一步 到这里已经安装好了 但是执行 jarsigner命令会看到 ‘jarsigner‘ 不是内部或外部命令解决方法 的报错 解决 可能是因为在bin 目录下没有 jarsigner.exe&#xff0c;没有的…

【Android 教程系列第 28 篇】Android 分别使用 jarsigner 和 apksigner 对 APK 签名(v1、v2 签名)的详细教程

这是【Android 教程系列第 28 篇】&#xff0c;如果觉得有用的话&#xff0c;欢迎关注专栏。 为了增加 Apk 的安全性&#xff0c;防止反编译&#xff0c;我们会对开发的 Apk 做签名处理&#xff0c;如果要上架应用商店&#xff0c;部分还会要求 Apk 必须加固后才能上架。 而对…

【Java可执行命令】(十)JAR文件签名工具 jarsigner:通过数字签名及验证保证代码信任与安全,深入解析 Java的 jarsigner命令~

Java可执行命令之jarsigner 1️⃣ 概念2️⃣ 优势和缺点3️⃣ 使用3.1 语法3.1.1 可选参数&#xff1a;jarsigner -keystore < url>3.1.2 可选参数&#xff1a;jarsigner -storepass <口令>3.1.3 可选参数&#xff1a;jarsigner -keypass <口令>3.1.4 可选参…

您的凭据不工作,请输入新凭据

转载自 http://m.blog.csdn.net/article/details?id47706021 今天上班同事说远程桌面无法使用&#xff0c;然后VNC连接&#xff0c;查看情况&#xff0c;密码是正确的&#xff0c;防火墙也关了&#xff0c;百思不得其解。 上网查询问题&#xff0c;找到一个解决办法&#xff0…

远程桌面连接提示“您的凭据不工作”

本次操作的是企图远程别人的电脑配置&#xff0c;而非被远程的电脑 在域环境中&#xff0c;如果使用Vista及以上的操作系统&#xff0c;默认情况下&#xff0c;在连接到远程计算机时无法保存凭据。 当我们使用远程桌面连接时&#xff0c;即使已经勾选了“记住我的凭证”。 但是…