返回顶部
首页 > 资讯 > 后端开发 > Python >详解mybatis中的if-else的嵌套使用
  • 813
分享到

详解mybatis中的if-else的嵌套使用

2024-04-02 19:04:59 813人浏览 安东尼

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

摘要

目录案例一:if-else案例二:if嵌套mybatis中if和choose的嵌套案例一:if-else 在mybatis的使用过程中,难免会存在使用if-else的逻辑,但是实际是

案例一:if-else

在mybatis的使用过程中,难免会存在使用if-else的逻辑,但是实际是没有这种语法的,提供了choose标签来替代这种语法

   <select id="selectUserByState" resultType="com.bz.model.entity.User">
    SELECT
      *
    FROM
      user
    WHERE
      1=1
    <choose>
      <when test="state == 1">
        AND name = #{name1}
      </when>
     <when test="state == 2">
        AND name = #{name2}
      </when>
      <otherwise>
        AND name = #{name3}
      </otherwise>
    </choose>
  </select>

案例二:if嵌套

在实际的编码过程中会对一些条件进行重复判断,并对内深入if判断,这时就可以使用if嵌套

  <select id="selectUserByState" resultType="com.bz.model.entity.User">
    SELECT
      *
    FROM
      user
    WHERE
     <if test=" gender!=null and gender!='' "> 
         <if test=" gender==male ">
             and name=#{name}
         </if>
     </if>
  </select>

MyBatis中if和choose的嵌套

    <!-- public List<VadtaxShow> findList(VadtaxShow vadtaxShow); -->
    <select id="findList" parameterType="com.cdqyzj_WC.Backstage.vaddedtax.domain.VaddeTax" resultType="com.cdqyzj_WC.Backstage.vaddedtax.domain.VaddeTax">
    SELECT t.addedId,t.taxType,t.totalSales,t.outputTax,t.inputTax,t.entryAmount, t.amountTax,t.retentionTax,
    t.createTime, t.taxTime,t.comId,c.comName,c.comType
    FROM t_g_vaddedtax AS t JOIN t_ucompany AS c ON c.comId = t.comId
    <where>
    1=1
            <if test="comType != '' and comType != null"> and c.comType = #{comType}</if>
            <if test="taxTime != null and taxTime != ''"> and t.taxTime =#{taxTime} </if>    
            <if test="taxType != null and taxType != '' "> and t.taxType =#{taxType} </if>
            <if test="comId != null and comId != '' and comId != 0 "> and t.comId =#{comId} </if>    
            <if test="start_times != null and end_times != null">
                <choose>
                    <when test="middle_times != null">
                        and t.createTime in ('${start_times}','${middle_times}', '${end_times}' )
                    </when>
                    <otherwise>
                        and t.createTime in ('${start_times}','${end_times}' )
                    </otherwise>
                </choose>
            </if>
            <if test="orderBy != null and orderType != '' ">
                     order by ${orderBy}  ${orderType}
            </if>
            <if test="pageSize != 0 ">
                    limit ${startRows},${pageSize}
            </if>
    </where>
    </select>

功能实现之后反思:要不我不对“middle_times”判空?这样不就不用嵌套了吗?

    <!-- public List<VadtaxShow> findList(VadtaxShow vadtaxShow); -->
    <select id="findList" parameterType="com.cdqyzj_WC.Backstage.vaddedtax.domain.VaddeTax" resultType="com.cdqyzj_WC.Backstage.vaddedtax.domain.VaddeTax">
    SELECT t.addedId,t.taxType,t.totalSales,t.outputTax,t.inputTax,t.entryAmount, t.amountTax,t.retentionTax,
    t.createTime, t.taxTime,t.comId,c.comName,c.comType
    FROM t_g_vaddedtax AS t JOIN t_ucompany AS c ON c.comId = t.comId
    <where>
    1=1
            <if test="comType != '' and comType != null"> and c.comType = #{comType}</if>
            <if test="taxTime != null and taxTime != ''"> and t.taxTime =#{taxTime} </if>    
            <if test="taxType != null and taxType != '' "> and t.taxType =#{taxType} </if>
            <if test="comId != null and comId != '' and comId != 0 "> and t.comId =#{comId} </if>    
            <if test="start_times != null and end_times != null">
                and t.createTime in ('${start_times}','${middle_times}', '${end_times}' )
            </if>
            <if test="orderBy != null and orderType != '' ">
                     order by ${orderBy}  ${orderType}
            </if>
            <if test="pageSize != 0 ">
                    limit ${startRows},${pageSize}
            </if>
    </where>
    </select>

到此这篇关于详解mybatis中的if-else的嵌套使用的文章就介绍到这了,更多相关mybatis if-else嵌套内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 详解mybatis中的if-else的嵌套使用

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

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

猜你喜欢
  • 详解mybatis中的if-else的嵌套使用
    目录案例一:if-else案例二:if嵌套MyBatis中if和choose的嵌套案例一:if-else 在mybatis的使用过程中,难免会存在使用if-else的逻辑,但是实际是...
    99+
    2024-04-02
  • mybatis中的if-else及if嵌套使用方式
    目录if-else及if嵌套使用方式案例一:if-else案例二:if嵌套mybatis if-else写法if-else及if嵌套使用方式 案例一:if-else 在使用mybat...
    99+
    2024-04-02
  • Python中在for循环中嵌套使用if和else语句的技巧
    for...[if]...构建List (List comprehension) 1.简单的for...[if]...语句 Python中,for...[if]...语句一种简洁的构建List的方法,从fo...
    99+
    2022-06-04
    嵌套 语句 技巧
  • mybatis中嵌套查询的使用解读
    目录mybatis嵌套查询的使用传递多个参数总结mybatis嵌套查询的使用 在使用mybatis时,当我们遇到表与表之之间存在关联的时候,就可以使用嵌套查询 比如说 当一个对象包含...
    99+
    2023-03-15
    mybatis嵌套查询 嵌套查询使用 mybatis查询
  • 解决Mybatis中foreach嵌套使用if标签对象取值的问题
    目录foreach嵌套使用if标签对象取值问题大体格式解决办法代码如下Mybatis if 语句嵌套要求foreach嵌套使用if标签对象取值问题 最近做项目过程中,涉及到需要在 M...
    99+
    2024-04-02
  • mybatis中foreach嵌套if标签的示例分析
    小编给大家分享一下mybatis中foreach嵌套if标签的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!mybatis foreach嵌套if标签代码实现:Mapper.java文件List<Map<...
    99+
    2023-06-29
  • Mybatis的xml中使用if/else标签的具体使用
    目录使用if标签进行查询where标签出场if/else 使用 choose,when,otherwise 代替使用if标签进行查询 SELECT ord...
    99+
    2024-04-02
  • 如何解决Mybatis中foreach嵌套使用if标签对象取值的问题
    今天小编给大家分享一下如何解决Mybatis中foreach嵌套使用if标签对象取值的问题的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来...
    99+
    2023-06-29
  • mybatis中的嵌套查询如何使用
    今天小编给大家分享一下mybatis中的嵌套查询如何使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。mybatis嵌套查询...
    99+
    2023-07-05
  • Java中避免写嵌套if样式的代码详解
    前言Optional的代码相对更加简洁,当代码量较大时,我们很容易忘记进行null判定,但是使用Optional类则会避免这类问题。下面这是一个嵌套的 if 判断,业务逻辑是从 httpRequst 中获取 X-Auth-Token 的值。...
    99+
    2023-05-31
    java if嵌套 ava
  • Vue中v-if、v-if-else、v-else-if与v-show的基本使用
    目录一、Vue的条件渲染1.1.v-if1.2.v-if-else1.3.v-else-if 1.4.template元素 1.5.v-show1.6.v...
    99+
    2022-11-13
    vue v-if v-show else if的用法 vue v-if else
  • MyBatis的嵌套查询解析
    Mybatis表现关联关系比hibernate简单,没有分那么细致one-to-many、many-to-one、one-to-one。而是只有两种association(一)、collection(多),表现很简洁。下面通过一个实例,来展...
    99+
    2023-05-31
    mybatis 嵌套 查询
  • 如何在python中使用if嵌套命令
    如何在python中使用if嵌套命令?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。python主要应用领域有哪些1、云计算,典型应用OpenStack。2、WE...
    99+
    2023-06-14
  • Python基础中的的if-else语句详解
    本节主要讲的是if条件不满足时,也可以给提示,就是走else 必须先做类型转换 另一种写法 if-else语句else后的冒号,必须是英文的… 下边为之前...
    99+
    2024-04-02
  • 基于shell的if和else详解
    基本语法 shell的if语法和C语言等高级语言非常相似,唯一需要注意的地方就是shell的if语句对空格方面的要求比较严格(其实shell对所有语法的空格使用都比较严格),如果在需要空格的地方没有打上空格...
    99+
    2022-06-04
    详解 shell
  • mybatis使用collection嵌套查询的实现
    在开发中,可能会遇到一对多的关系,这个时候,一条sql语句就难以胜任这个任务了。只能先执行一条sql,然后根据返回的结果,再做一次sql关联查询,这个时候,使用mybatis的col...
    99+
    2024-04-02
  • 在Python的while循环中使用else以及循环嵌套的用法
    循环使用 else 语句 在 python 中,for … else 表示这样的意思,for 中的语句和普通的没有区别,else 中的语句会在循环正常执行完(即 for 不是通过 break 跳出而中断的)...
    99+
    2022-06-04
    嵌套 Python
  • 详解Shell if else语句的具体使用方法
    和其它编程语言类似,Shell 也支持选择结构,并且有两种形式,分别是 if else 语句和 case in 语句。本节我们先介绍 if else 语句,case in 语句将会在《Shell case in》中介绍。...
    99+
    2022-06-04
    Shell if else语句
  • sql中if else的用法
    if else 语句允许在 sql 查询中基于条件执行不同操作。它用于条件检查,根据结果执行 then 或 else 中指定的语句。语法为:if 条件 then 操作1 else 操作2...
    99+
    2024-04-28
  • oracle中if else的用法
    oracle 中的 if else 语句根据条件执行不同的代码块。它使用 if (condition) then...else...end if 语法,其中 condition 是布尔表...
    99+
    2024-05-07
    oracle
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作