iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >MyBatis动态<if>标签如何使用
  • 646
分享到

MyBatis动态<if>标签如何使用

2023-07-05 10:07:42 646人浏览 薄情痞子
摘要

这篇文章主要介绍“mybatis动态<if>标签如何使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MyBatis动态<if>标签如何使用”文章能帮助大家解决问题。一. i

这篇文章主要介绍“mybatis动态<if>标签如何使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MyBatis动态<if>标签如何使用”文章能帮助大家解决问题。

一. 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',所以这里有坑,切记。

关于“MyBatis动态<if>标签如何使用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网精选频道,小编每天都会为大家更新不同的知识点。

--结束END--

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

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

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

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

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

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

  • 微信公众号

  • 商务合作