服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - Mybatis的xml中使用if/else标签的具体使用

Mybatis的xml中使用if/else标签的具体使用

2022-12-15 15:38Hi梅 Java教程

本文主要介绍了Mybatis的xml中使用if/else标签的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

使用if标签进行查询

?
1
2
3
4
5
6
7
8
9
10
11
12
13
SELECT
    orderNo,
    adname,
    orderstatus
FROM
    order_A
where
    <if test="order!=null">
        order=#{order}
    </if>
    <if test="title!=null">
        and title=#{title}
    </if>

需要注意的是:如果第一个if的order为null的话 第二值title也为null的话运行会报错,就算第一个if等于null 那么查询语句变成 where and sql" id="highlighter_26932">

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
SELECT
    orderNo,
    adname,
    orderstatus
FROM
    order_A
<where>
    <if test="order!=null">
        order=#{order}
    </if>
    <if test="order!=null">
        and title=#{title}
    </if>
</where>

where 元素只会在至少有一个子元素的条件返回 SQL 子句的情况下才去插入WHERE子句。而且,若语句的开头为AND或OR,where 元素也会将它们去除。这个只能解决2个值都为空。
不能解决order值为空但是title值为空时还是会出现语句错误的情况,这个时候我们可以在and 前面用1=1或者true来解决

如:

Mybatis的xml中使用if/else标签的具体使用

或这样

Mybatis的xml中使用if/else标签的具体使用

if/else 使用 choose,when,otherwise 代替

由于Mybatis中没有else标签但是可以通过choose,when,otherwise来使用

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
SELECT
            orderNo,
            adname,
            orderstatus
FROM
    <choose>
        <when test=" platformtype != null and platformtype.trim() != '' and platformtype == 1">
             `orders_A` as orderTable
        </when>
        <when test=" platformtype != null and platformtype.trim() != '' and platformtype == 2">
             `orders_B` as orderTable
        </when>
        <when test="  platformtype != null and platformtype.trim() != '' and platformtype == 3">
             `orders_C` as orderTable
        </when>
        <otherwise>
             `orders_A` as orderTable
        </otherwise>
    </choose>

翻译一下上面的语句:

当platformtype 值不为空并且把platformtype 值进行去除空字符串,并且值等于1时
就会把表orders_A进行拼接,如果条件都不符合的话就会走otherwise标签默认拼接orders_A表进行查询

choose,when,otherwise标签有点像Java中的switch 当where的test值满足时会拼接里面的表,otherwise表示其他when标签都不满足时执行拼接

到此这篇关于Mybatis的xml中使用if/else标签的具体使用的文章就介绍到这了,更多相关Mybatis xml=使用if/else标签内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/qq_45502336/article/details/118275412

延伸 · 阅读

精彩推荐