iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >MyBatis动态<if>标签的使用
  • 268
分享到

MyBatis动态<if>标签的使用

MyBatis动态<if>标签MyBatis<if>标签 2023-05-19 20:05:00 268人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

目录前言正文一. if标签判断字符串二. if标签判断数字总结前言 MyBatis中的<if>动态SQL标签,常用场景是根据条件添加WHERE子句。本篇文章将对&

前言

MyBatis中的<if>动态SQL标签,常用场景是根据条件添加WHERE子句。本篇文章将对<if>动态SQL标签使用中的常见问题进行演示和总结。

演示的场景有:if判断字符串if判断数字

MyBatis版本:3.5.6

正文

一. if标签判断字符串

查询参数Param如下。

public class Param {
    private int id;
    private String level;
    private int times;
    private String timestamp;
    // 省略get和set
}

语句如下。

<select id="queryEvents" resultMap="eventResultMap">
    SELECT
        id,
        e_name,
        e_times,
        e_level
    FROM event
    WHERE id=#{id}
    <if test="level != null and level != ''">
        AND e_level=#{level}
    </if>
</select>

上述是判断字符串是否为空(null或者空串),不为空时,为WHERE子句添加额外的条件。

通过<if>标签判断字符串是否为空,是<if>标签使用频率最高的用法,但是有时也会通过<if>标签来判断字符串的值,这里有多种写法,下面给出正确写法推荐写法错误写法

正确写法1

<select id="queryEvents" resultMap="eventResultMap">
    SELECT
        id,
        e_name,
        e_times,
        e_level
    FROM event
    WHERE id=#{id}
    <if test="level == 'secondary'">
        AND e_times>10
    </if>
</select>

注意''单引号中一定需要是多个字符,如果只有一个字符,会报错。

正确写法2

<select id="queryEvents" resultMap="eventResultMap">
    SELECT
        id,
        e_name,
        e_times,
        e_level
    FROM event
    WHERE id=#{id}
    <if test="level == 'secondary'.toString()">
        AND e_times>10
    </if>
</select>

这种写法不限制''单引号中的字符个数,一个或多个都可以。

推荐写法

<select id="queryEvents" resultMap="eventResultMap">
    SELECT
        id,
        e_name,
        e_times,
        e_level
    FROM event
    WHERE id=#{id}
    <if test='level == "secondary"'>
        AND e_times>10
    </if>
</select>

推荐外层用单引号,内层用双引号的写法,能少踩很多坑

特别注意:错误写法

<select id="queryEvents" resultMap="eventResultMap">
    SELECT
        id,
        e_name,
        e_times,
        e_level
    FROM event
    WHERE id=#{id}
    <if test="level == 'A'">
        AND e_times>10
    </if>
</select>

这种写法会报错,因为像'A'这种单个字符的情况会被判定为字符,所以MyBatis认为字符串在与字符做比较,从而报错。但是如果是'AA'或者'A'.toString() 这种,就会被判定为字符串,就正常。

二. if标签判断数字

查询参数Param如下。

public class Param {
    private int id;
    private String level;
    private int times;
    private String timestamp;
    // 省略get和set
}

语句如下。

<select id="queryEvents3" resultMap="eventResultMap">
    SELECT
        id,
        e_name,
        e_times,
        e_level
    FROM event
    WHERE e_level=#{level}
    <if test="times != null">
        AND e_times>#{times}
    </if>
</select>

通过<if>标签也可以对数字判空,同时<if>标签也可以判断数字的值,这里有多种写法,下面给出正确写法,推荐写法和错误写法。

正确写法1

<select id="queryEvents2" resultMap="eventResultMap">
    SELECT
        id,
        e_name,
        e_times,
        e_level
    FROM event
    WHERE e_level=#{level}
    <if test="times > '10'">
        AND e_times>#{times}
    </if>
</select>

注意''单引号中一定需要是多个数字。

正确写法2

<select id="queryEvents2" resultMap="eventResultMap">
    SELECT
        id,
        e_name,
        e_times,
        e_level
    FROM event
    WHERE e_level=#{level}
    <if test="times > '0'.toString()">
        AND e_times>#{times}
    </if>
</select>

这种写法不限制''单引号中的数字个数,一个或多个都可以。

正确写法3

<select id="queryEvents" resultMap="eventResultMap">
    SELECT
        id,
        e_name,
        e_times,
        e_level
    FROM event
    WHERE e_level=#{level}
    <if test="times > 0">
        AND e_times>#{times}
    </if>
</select>

判断条件可以直接写数字。

推荐写法

<select id="queryEvents2" resultMap="eventResultMap">
    SELECT
        id,
        e_name,
        e_times,
        e_level
    FROM event
    WHERE e_level=#{level}
    <if test='times > "0"'>
        AND e_times>#{times}
    </if>
</select>

推荐外层用单引号,内层用双引号的写法,能少踩很多坑

错误写法

<select id="queryEvents" resultMap="eventResultMap">
    SELECT
        id,
        e_name,
        e_times,
        e_level
    FROM event
    WHERE e_level=#{level}
    <if test="times > '0'">
        AND e_times>#{times}
    </if>
</select>

'0'这种单个数字会被判定为字符,而字符'0'的ASCII值是48,所以times为49及以上时,才满足times > '0',所以这里有坑,切记

总结

<if>标签的test判断中,外层用双引号,内层用单引号时,有如下比较规则。

  • 允许数字与字符串做比较;
  • 允许数字与字符做比较,但不推荐。数字与字符做比较时,数字会与字符的ASCAII值做比较,容易出错;
  • 不允许包含字母的字符串与字符做比较。这种情况MyBatis会直接报错;
  • 允许全是数字的字符串与字符做比较,但不推荐。这种情况全是数字的字符串会作为数字来与字符的ASCII值来做比较,容易出错。

而在OGNL表达式中,如果单引号''中只有一个数字或者字母,那么就会被解析为字符,这时就会导致MyBatis或者比较结果错误。

因此推荐<if>标签的test判断中,外层用单引号,内层用双引号,能够避免踩坑

到此这篇关于mybatis动态<if>标签的使用的文章就介绍到这了,更多相关MyBatis动态<if>标签内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: MyBatis动态<if>标签的使用

本文链接: https://www.lsjlt.com/news/213733.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MyBatis动态<if>标签的使用
    目录前言正文一. if标签判断字符串二. if标签判断数字总结前言 MyBatis中的<if>动态SQL标签,常用场景是根据条件添加WHERE子句。本篇文章将对&...
    99+
    2023-05-19
    MyBatis动态<if>标签 MyBatis <if>标签
  • MyBatis动态<if>标签如何使用
    这篇文章主要介绍“MyBatis动态<if>标签如何使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MyBatis动态<if>标签如何使用”文章能帮助大家解决问题。一. i...
    99+
    2023-07-05
  • mybatis <foreach>标签动态增删改查方式
    目录<foreach>标签动态增删改查mybatis<foreach>实战有了建表以及插入,当然少不了删除和更新mapper.xml中<foreach&...
    99+
    2024-04-02
  • mybatis中<choose>标签怎么使用
    本文小编为大家详细介绍“mybatis中<choose>标签怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“mybatis中<choose>标签怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一...
    99+
    2023-06-30
  • mybatis中<choose>标签的用法说明
    目录choose标签用法choose动态用法choose标签用法 choose 标签是按顺序判断其内部 when 标签中的 test 条件出否成立,如果有一个成立,则 choose ...
    99+
    2024-04-02
  • html中<Table> <tr> <th> <td>表格标签怎么用
    这篇文章将为大家详细讲解有关html中<Table> <tr> <th> <td>表格标签怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇...
    99+
    2024-04-02
  • <include>标签在mybatis中的作用是什么
    <include>标签在mybatis中的作用是什么?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。MyBatis中sql标签定义SQL片段,include标签引...
    99+
    2023-06-06
  • HTML的<iframe>标签如何使用
    这篇文章主要讲解了“HTML的<iframe>标签如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“HTML的<iframe>标...
    99+
    2024-04-02
  • html中<dl> <dt> <dd> 标签元素怎么用
    这篇文章主要介绍了html中<dl> <dt> <dd> 标签元素怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家...
    99+
    2024-04-02
  • html的<span>标签如何使用
    本文小编为大家详细介绍“html的<span>标签如何使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“html的<span>标签如何使用”文章能帮助大家解决疑惑,下面跟着小编的思...
    99+
    2024-04-02
  • HTML的<script>标签怎么使用
    这篇“HTML的<script>标签怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起...
    99+
    2024-04-02
  • HTML的<video>标签如何使用
    这篇“HTML的<video>标签如何使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来...
    99+
    2024-04-02
  • HTML的<base>标签怎么使用
    这篇文章主要介绍“HTML的<base>标签怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“HTML的<base>标签怎么使用”文章能...
    99+
    2024-04-02
  • Mybatis中<if>和<choose>的区别及“=”判断方式
    目录<if>和<choose>的区别及“=”判断正确很好的写法需要引入<choose>标签<!--错误的写法--&g...
    99+
    2024-04-02
  • html <title>标签如何使用
    本篇内容主要讲解“html <title>标签如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“html <title>标签如何使用...
    99+
    2024-04-02
  • html中如何使用<code>标签
    这篇文章主要介绍了html中如何使用<code>标签,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 在介绍语言技术的网站中,必...
    99+
    2024-04-02
  • html如何使用<ul><li>无序列表标签
    这篇文章主要为大家展示了“html如何使用<ul><li>无序列表标签”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“html如何使用&l...
    99+
    2024-04-02
  • html中<font>标签怎么使用
    这篇文章将为大家详细讲解有关html中<font>标签怎么使用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、font标签语法与结构   ...
    99+
    2024-04-02
  • HTML的<nobr>标签怎么用
    本篇内容主要讲解“HTML的<nobr>标签怎么用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“HTML的<nobr>标签怎么用”吧! ...
    99+
    2024-04-02
  • HTML的<basefont>标签怎么用
    小编给大家分享一下HTML的<basefont>标签怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!   HT...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作