专栏首页Java冰冻三尺​MyBatis必知知识点:trim标签的使用

​MyBatis必知知识点:trim标签的使用

作者:wt_better 链接: blog.csdn.net/wt_better/article/details/80992014

MyBatis的trim标签一般用于去除sql语句中多余的and关键字,逗号,或者给sql语句前拼接 “where“、“set“以及“values(“ 等前缀,或者添加“)“等后缀,可用于选择性插入、更新、删除或者条件查询等操作。

以下是trim标签中涉及到的属性:

下面使用几个例子来说明trim标签的使用。

1、使用trim标签去除多余的and关键字

有这样的一个例子:

<select id="findActiveBlogLike"
     resultType="Blog">
  SELECT * FROM BLOG 
  WHERE 
  <if test="state != null">
    state = #{state}
  </if> 
  <if test="title != null">
    AND title like #{title}
  </if>
  <if test="author != null and author.name != null">
    AND author_name like #{author.name}
  </if>
</select>

如果这些条件没有一个能匹配上会发生什么?最终这条 SQL 会变成这样:

SELECT * FROM BLOG
WHERE

这会导致查询失败。如果仅仅第二个条件匹配又会怎样?这条 SQL 最终会是这样:

SELECT * FROM BLOG
WHERE 
AND title like ‘someTitle’

你可以使用where标签来解决这个问题,where 元素只会在至少有一个子元素的条件返回 SQL 子句的情况下才去插入“WHERE”子句。而且,若语句的开头为“AND”或“OR”,where 元素也会将它们去除。

<select id="findActiveBlogLike"
     resultType="Blog">
  SELECT * FROM BLOG 
  <where> 
    <if test="state != null">
         state = #{state}
    </if> 
    <if test="title != null">
        AND title like #{title}
    </if>
    <if test="author != null and author.name != null">
        AND author_name like #{author.name}
    </if>
  </where>
</select>

trim标签也可以完成相同的功能,写法如下:

<trim prefix="WHERE" prefixOverrides="AND">
    <if test="state != null">
      state = #{state}
    </if> 
    <if test="title != null">
      AND title like #{title}
    </if>
    <if test="author != null and author.name != null">
      AND author_name like #{author.name}
    </if>
</trim>

2、使用trim标签去除多余的逗号

有如下的例子:

如果红框里面的条件没有匹配上,sql语句会变成如下:

INSERT INTO role(role_name,) VALUES(roleName,)

插入将会失败。

使用trim标签可以解决此问题,只需做少量的修改,如下所示:

其中最重要的属性是

suffixOverrides=","

表示去除sql语句结尾多余的逗号.

注:如果你有兴趣的话,也可以研究下Mybatis逆向工程生成的Mapper文件,其中也使用了trim标签,但结合了foreach、choose等标签,更多的是牵扯到Criterion的源码研究。不过研究完之后,你将熟练掌握mybatis各种标签的使用,学到Criterion的设计思想,对自己的启发将会很大。

微信搜索:【Java小咖秀】,更多精彩等着您~

回复【手册】获取博主15万字(80%原创) 《Java面试通关手册》 & 《Linux命令实战手册》~

原文链接:http://blog.csdn.net/wt_better/article/details/80992014

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 简单的 CAS 实现 SSO 单点登录

    解压缩 cas-4.1.8.zip 并进入 cas-server-webapp 目录,在当前目录打开 cmd 并执行安装命令。

    Java小咖秀
  • 面试官拿System.out.println()考了我半个小时?我傻了

    如果你能自己读懂System.out.println(),就真正了解了Java面向对象编程的含义

    Java小咖秀
  • 并发业务中,线程安全与否很重要,来看看你懂多少?

    链接: https://juejin.im/post/5b7d68f66fb9a019d80a9002

    Java小咖秀
  • Android--关闭某个指定activity

    最近项目中有这样的需要,在关闭当前Activity同时关闭前面两个Activity,不涉及到应用的退出。自己想了一些方案,也查了一些资料,做个笔记吧。

    Android技术干货分享
  • 【小家Spring】细说Spring IOC容器的自动装配(@Autowired),以及Spring4.0新特性之【泛型依赖注入】的源码级解析

    前面我发布了Spring IOC容器的刷新(初始化)过程,以及Spring 容器的Bean的实例化、初始化过程。其中有一个步骤小伙伴们比较关心,也提问的比较多,...

    YourBatman
  • Python程序结构

    4种流程控制语句结构: if if -- else if -- elif --else if多条件

    潇洒坤
  • SQL字典式教程

    SQL(Structure Query Language)又称结构化设计语言。是一门数据库语言,其作用包括数据定义Statistic Define、数据操纵Ma...

    EatRice
  • 技术角 | 架构学习书摘总结(五)架构实战(中)

    最近阅读了一本架构方面的入门图书叫《从零开始学架构:照着做,你也能成为架构师》,部分内容比较不错,先做书摘总结,以便加深印象与未来回顾学习。

    ZNing
  • 大疆无人机控制应用 DJI Go 4 监视用户? 谷歌已展开调查

    外媒报道称,安全公司Synacktiv和Grimm的研究人员表示,「大疆的无人机控制应用 DJI Go 4 可能并不安全。」

    新智元
  • Cron,Chkconfig,Systemd,Target

    Cron : # cat /etc/crontab //查看设置任务计划的(配置文件)格式 #crontab -e //自定义计划内容 0 3 * * * /b...

    老七Linux

扫码关注云+社区

领取腾讯云代金券