国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

MyBatis 動態(tài)SQL之<choose><when><o(jì)therwise>標(biāo)簽-

這篇具有很好參考價值的文章主要介紹了MyBatis 動態(tài)SQL之<choose><when><o(jì)therwise>標(biāo)簽-。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

簡介

MyBatis 中動態(tài)語句 choose-when-otherwise 類似于 Java 中的 switch-case-default 語句。由于 MyBatis 并沒有為 if 提供對應(yīng)的 else 標(biāo)簽,如果想要達(dá)到…… 的效果,可以借助 、、 來實現(xiàn)。

語法

<choose>
    <when test="判斷條件1">
        SQL語句1
    </when >
    <when test="判斷條件2">
        SQL語句2
    </when >
    <when test="判斷條件3">
        SQL語句3
    </when >
    <otherwise>
        SQL語句4
    </otherwise>
</choose>

hoose 標(biāo)簽按順序判斷其內(nèi)部 when 標(biāo)簽中的判斷條件是否成立,如果有一個成立,則執(zhí)行相應(yīng)的 SQL 語句,choose 執(zhí)行結(jié)束;如果都不成立,則執(zhí)行 otherwise 中的 SQL 語句。這類似于 Java 的 switch 語句,choose 為 switch,when 為 case,otherwise 則為 default。

場景示例

MyBatis 就會根據(jù)參數(shù)的設(shè)置進(jìn)行判斷來動態(tài)組裝 SQL
以下示例要求:

  • 當(dāng)網(wǎng)站名稱不為空時,只用網(wǎng)站名稱作為條件進(jìn)行模糊查詢;
  • 當(dāng)網(wǎng)站名稱為空,而網(wǎng)址不為空時,則用網(wǎng)址作為條件進(jìn)行模糊查詢;
  • 當(dāng)網(wǎng)站名稱和網(wǎng)址都為空時,則要求網(wǎng)站年齡不為空。
<mapper namespace="net.biancheng.mapper.WebsiteMapper">
    <select id="selectWebsite"
        parameterType="net.biancheng.po.Website"
        resultType="net.biancheng.po.Website">
        SELECT id,name,url,age,country
        FROM website WHERE 1=1
        <choose>
            <when test="name != null and name !=''">
                AND name LIKE CONCAT('%',#{name},'%')
            </when>
            <when test="url != null and url !=''">
                AND url LIKE CONCAT('%',#{url},'%')
            </when>
            <otherwise>
                AND age is not null
            </otherwise>
        </choose>
    </select>
</mapper>

choose-when-otherwise標(biāo)簽-完整案例

1.數(shù)據(jù)庫準(zhǔn)備

# 創(chuàng)建一個名稱為t_customer的表
CREATE TABLE t_customer (
    id int(32) PRIMARY KEY AUTO_INCREMENT,
    username varchar(50),
    jobs varchar(50),
    phone varchar(16)
);
# 插入3條數(shù)據(jù)
INSERT INTO t_customer VALUES ('1', 'joy', 'teacher', '13733333333');
INSERT INTO t_customer VALUES ('2', 'jack', 'teacher', '13522222222');
INSERT INTO t_customer VALUES ('3', 'tom', 'worker', '15111111111');

2.新建項目或Module

<choose><when>,mybatis,mybatis,sql,java

3 pom.xml中添加

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId>mybatis</artifactId>
        <groupId>com.example</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.biem</groupId>
    <artifactId>dynamaicSql</artifactId>

    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
    </properties>

    <dependencies>
        <!--1.引入mybatis包-->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.4.6</version>
        </dependency>
        <!--2.單元測試-->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>test</scope>
        </dependency>

        <!--3.mysql驅(qū)動-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.18</version>
            <scope>runtime</scope>
        </dependency>

        <!--4.log4j日志-->
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.16</version>
        </dependency>
    </dependencies>
</project>

4.創(chuàng)建package和文件夾

src/main/java/下創(chuàng)建package
com.biem.pojo
com.biem.mapper
com.biem.util
src/main/resources/下創(chuàng)建文件夾
com/biem/mapper
src/test/java下創(chuàng)建package
com.biem.test

5 框架配置文件

5.1 mybatis核心配置文件mybatis-config.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <!--引入properties文件-->
    <properties resource="jdbc.properties"></properties>

    <!--將下劃線映射為駝峰-->
    <settings>
        <setting name="mapUnderscoreToCamelCase" value="true"/>
    </settings>

    <!--設(shè)置類型別名-->
    <typeAliases>
        <!--
            以包為單位,將包下所有的類型設(shè)置設(shè)置默認(rèn)的類型別名,即類名且不區(qū)分大小寫
        -->
        <package name="com.biem.pojo"/>
    </typeAliases>

    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="${jdbc.driver}"/>
                <property name="url" value="${jdbc.url}"/>
                <property name="username" value="${jdbc.username}"/>
                <property name="password" value="${jdbc.password}"/>
            </dataSource>
        </environment>

    </environments>

    <!-- 引入映射文件 -->
    <mappers>
        <!--
            以包為單位引入映射文件
            要求:
            1. mapper接口所在的包要和映射文件所在的包一致
            2. mapper接口要和映射文件的名字一致
        -->
        <package name="com.biem.mapper"/>
    </mappers>


</configuration>

5.2 mybatis屬性文件jdbc.properties

jdbc.driver=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/mybatis?serverTimezone=UTC
jdbc.username=root
jdbc.password=root

5.3 log4j.xml文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">

<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">

    <appender name="STDOUT" class="org.apache.log4j.ConsoleAppender">
        <param name="Encoding" value="UTF-8"/>
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%-5p %d{MM-dd HH:mm:ss,SSS} %m (%F:%L) \n"/>
        </layout>
    </appender>
    <logger name="java.sql">
        <level value="debug"/>
    </logger>
    <logger name="org.apache.ibatis">
        <level value="info"/>
    </logger>
    <root>
        <level value="debug"/>
        <appender-ref ref="STDOUT"/>
    </root>
</log4j:configuration>

6 用戶配置文件

6.1 實體類

package com.biem.pojo;

import lombok.*;

/**
 * ClassName: Customer
 * Package: com.biem.pojo
 * Description:
 *
 * @Create 2023/4/5 22:17
 * @Version 1.0
 */
@Getter
@Setter
@NoArgsConstructor
@AllArgsConstructor
@Builder
@ToString
public class Customer {
    private Integer id;
    private String username;
    private String jobs;
    private String phone;
}

需要在pom.xml中引入lombok,簡化原來的實體類的代碼

6.2 mybatis接口類

package com.biem.mapper;

/**
 * ClassName: CustomerMapper
 * Package: com.biem.mapper
 * Description:
 *
 * @Create 2023/4/5 22:19
 * @Version 1.0
 */
public interface CustomerMapper {
}

6.3 mybatis用戶配置文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.biem.mapper.CustomerMapper">
    <!-- namespace要和mapper接口的全類名保持一致,例如com.biem.mybatis.mapper.xxxMapper -->

    <!-- sql語句要和接口的方法名保持一致 -->

</mapper>

6.4 mybatis工具類

package com.biem.util;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import java.io.IOException;
import java.io.InputStream;

/**
 * ClassName: MybatisUtil
 * Package: com.biem.utils
 * Description:
 *
 * @Create 2023/4/5 22:23
 * @Version 1.0
 */
public class MybatisUtil {
    //利用static(靜態(tài))屬于類不屬于對象,且全局唯一
    private static SqlSessionFactory sqlSessionFactory = null;
    //利用靜態(tài)塊在初始化類時實例化sqlSessionFactory
    static {
        InputStream is= null;
        try {
            is = Resources.getResourceAsStream("mybatis-config.xml");
            sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
        } catch (IOException e) {
            e.printStackTrace();
            throw new ExceptionInInitializerError(e);
        }
    }

    /**
     * openSession 創(chuàng)建一個新的SqlSession對象
     * @return SqlSession對象
     */
    public static SqlSession openSession(boolean autoCommit){
        return sqlSessionFactory.openSession(autoCommit);
    }

    public static SqlSession openSession(){
        return sqlSessionFactory.openSession();
    }
    /**
     * 釋放一個有效的SqlSession對象
     * @param session 準(zhǔn)備釋放SqlSession對象
     */
    public static void closeSession(SqlSession session){
        if(session != null){
            session.close();
        }
    }
}

項目結(jié)構(gòu)如下
<choose><when>,mybatis,mybatis,sql,java

7 標(biāo)簽功能測試

在使用if標(biāo)簽時,只要test屬性中的表達(dá)式為true,就會執(zhí)行元素中的條件語句,但是在實際情況下有時只需要從多個選項中選擇一個去執(zhí)行,比如下面的場景:
當(dāng)查詢數(shù)據(jù)庫t_customer時,
客戶姓名不為空,則只根據(jù)客戶名稱進(jìn)行客戶篩選,
當(dāng)客戶名稱為null的時候,可客戶職業(yè)不為空,則根據(jù)客戶職業(yè)進(jìn)行篩選,
當(dāng)客戶名稱和客戶職業(yè)都為空的時候,要求查詢電話不為空的客戶

7.1 com.biem.mapper.CustomerMapper.class中添加

public List<Customer> findCustomerByCondition(Customer customer);

7.2 com/biem/mapper/CustomerMapper.xml中添加

    <!-- public List<Customer> findCustomerByCondition(Customer customer);-->
    <select id="findCustomerByCondition" parameterType="customer" resultType="customer">
        select * from t_customer where 1=1
        <!--條件判斷-->
        <choose>
            <when test="username!=null and username!=''">
                and username like concat('%',#{username},'%')
            </when>
            <when test="jobs!=null and jobs!=''">
                and jobs=#{jobs}
            </when>
            <otherwise>
                and phone is not null
            </otherwise>
        </choose>
    </select>

8 功能測試

在src/test/java中創(chuàng)建類com.biem.test.TestCustomer.java,內(nèi)容如下文章來源地址http://www.zghlxwxcb.cn/news/detail-700824.html

package com.biem.test;

import com.biem.mapper.CustomerMapper;
import com.biem.pojo.Customer;
import com.biem.util.MybatisUtil;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;

import java.util.List;

/**
 * ClassName: TestCustomer
 * Package: com.biem.test
 * Description:
 *
 * @Create 2023/4/5 22:32
 * @Version 1.0
 */
public class TestCustomer {

    @Test
    public void testFindAll(){
        // 通過工具類獲取SqlSession對象
        SqlSession session = MybatisUtil.openSession();
        // 創(chuàng)建Customer對象,封裝需要組合查詢的條件
        Customer customer = new Customer();

        CustomerMapper mapper = session.getMapper(CustomerMapper.class);
        List<Customer> customers = mapper.findCustomerByCondition(customer);

        System.out.println("customers = " + customers);

        // 關(guān)閉SqlSession
        session.close();
    }

    @Test
    public void testFindCustomerByName(){
        // 通過工具類獲取SqlSession對象
        SqlSession session = MybatisUtil.openSession();
        // 創(chuàng)建Customer對象,封裝需要組合查詢的條件
        Customer customer = new Customer();
        customer.setUsername("jack");

        CustomerMapper mapper = session.getMapper(CustomerMapper.class);
        List<Customer> customers = mapper.findCustomerByCondition(customer);

        System.out.println("customers = " + customers);

        // 關(guān)閉SqlSession
        session.close();
    }

    @Test
    public void testFindCustomerByJobs(){
        // 通過工具類獲取SqlSession對象
        SqlSession session = MybatisUtil.openSession();
        // 創(chuàng)建Customer對象,封裝需要組合查詢的條件
        Customer customer = new Customer();
        customer.setJobs("teacher");

        CustomerMapper mapper = session.getMapper(CustomerMapper.class);
        List<Customer> customers = mapper.findCustomerByCondition(customer);

        System.out.println("customers = " + customers);

        // 關(guān)閉SqlSession
        session.close();
    }

    @Test
    public void testFindCustomerByPhone(){
        // 通過工具類獲取SqlSession對象
        SqlSession session = MybatisUtil.openSession();
        // 創(chuàng)建Customer對象,封裝需要組合查詢的條件
        Customer customer = new Customer();
        customer.setPhone("1");

        CustomerMapper mapper = session.getMapper(CustomerMapper.class);
        List<Customer> customers = mapper.findCustomerByCondition(customer);

        System.out.println("customers = " + customers);

        // 關(guān)閉SqlSession
        session.close();
    }
}

到了這里,關(guān)于MyBatis 動態(tài)SQL之<choose><when><o(jì)therwise>標(biāo)簽-的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進(jìn)行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • Mybatis是什么?Mybatis中動態(tài)sql常用標(biāo)簽有哪些?

    Mybatis是什么? Mybatis是一種開源的Java持久層框架,它可以將SQL語句和Java代碼進(jìn)行分離,使得開發(fā)人員可以更加專注于業(yè)務(wù)邏輯的實現(xiàn)。與Hibernate等ORM框架不同的是,Mybatis使用XML或注解的方式來描述SQL語句,這種方式更加靈活,因此在一些需要高度自定義SQL語句的場景下,

    2024年02月05日
    瀏覽(31)
  • MyBatis 動態(tài)SQL之<where>標(biāo)簽-

    MyBatis 動態(tài)SQL之<where>標(biāo)簽-

    where 標(biāo)簽主要用來簡化 SQL 語句中的條件判斷,可以自動處理 AND/OR 條件。 在if標(biāo)簽和choose-when-otherwise標(biāo)簽的案例中,SQL語句加入了一個條件’1=1’,它既保證了where后面的條件成,頁避免了where后面出現(xiàn)的第一個詞語是and 或者or之類的。 假設(shè)把條件‘1=1’去掉,可以出

    2024年02月11日
    瀏覽(31)
  • MyBatis 動態(tài)SQL的標(biāo)簽有哪些?如何使用?

    MyBatis 動態(tài)SQL的標(biāo)簽有哪些?如何使用?

    目錄 1. MyBatis 動態(tài)SQL標(biāo)簽有什么用? 2. if 標(biāo)簽 3. where 標(biāo)簽 4. trim 標(biāo)簽 5. choose,when,otherwise 6. foreach 1. MyBatis 動態(tài)SQL標(biāo)簽有什么用? 我來說一個場景大家就明白了,如下圖,大家應(yīng)該在鐵路12306上買過火車票吧,可以看到,我們在選票的時候可以對車做很多種選擇和篩選,系

    2024年02月11日
    瀏覽(49)
  • 數(shù)據(jù)庫操作不再困難,MyBatis動態(tài)Sql標(biāo)簽解析

    數(shù)據(jù)庫操作不再困難,MyBatis動態(tài)Sql標(biāo)簽解析

    MyBatis緩存原理 Mybatis的CachingExecutor與二級緩存 Mybatis plugin 的使用及原理 MyBatis四大組件Executor、StatementHandler、ParameterHandler、ResultSetHandler 詳解 MyBatis+Springboot 啟動到SQL執(zhí)行全流程 使用MyBatis,或者M(jìn)yBatis-plus,有一項重要的開發(fā)技能就是寫動態(tài)sql,動態(tài)sql能幫我們省略很多復(fù)雜邏

    2024年02月12日
    瀏覽(34)
  • MyBatis動態(tài)sql之批量修改、批量新增(使用foreach標(biāo)簽的一條sql語句解決)

    ????????批量新增和批量修改在業(yè)務(wù)中是很常見的,一條sql訪問數(shù)據(jù)庫和通過代碼循環(huán)體中循環(huán)訪問數(shù)據(jù)庫做單個數(shù)據(jù)新增修改相比較下:一條sql訪問數(shù)據(jù)庫性能上明顯提升,代碼且簡潔明了 1、Mapper.java中 說明: 參數(shù)是list ?2、Mapper.xml中 說明: 通過trim標(biāo)簽拼接前后綴和

    2024年02月10日
    瀏覽(22)
  • MyBatis的代理開發(fā)方式、動態(tài)sql語句和typeHandlers和plugins標(biāo)簽實戰(zhàn)

    MyBatis的代理開發(fā)方式、動態(tài)sql語句和typeHandlers和plugins標(biāo)簽實戰(zhàn)

    接上篇博客: MyBatis基礎(chǔ)知識和快速入門、MyBatis核心配置文件講解,本文繼續(xù)講解MyBatis動態(tài)SQL語句、typeHandlers和plugins標(biāo)簽。 傳統(tǒng)開發(fā)方式 編寫UserDao接口 編寫UserDaoImpl實現(xiàn) mapper文件 測試傳統(tǒng)方式 代理開發(fā)方式 代理開發(fā)方式介紹 采用 Mybatis 的代理開發(fā)方式實現(xiàn) DAO 層的開發(fā)

    2023年04月27日
    瀏覽(21)
  • 深入解析 MyBatis 中的 <;foreach>; 標(biāo)簽:優(yōu)雅處理批量操作與動態(tài) SQL

    在當(dāng)今的Java應(yīng)用程序開發(fā)中,數(shù)據(jù)庫操作是一個不可或缺的部分。MyBatis作為一款頗受歡迎的持久層框架,為我們提供了一種優(yōu)雅而高效的方式來管理數(shù)據(jù)庫操作。在MyBatis的眾多特性中, foreach 標(biāo)簽無疑是一個強(qiáng)大的工具,它使得在SQL語句中進(jìn)行動態(tài)循環(huán)迭代變得輕而易舉。

    2024年02月13日
    瀏覽(22)
  • Mybatis 常用條件語句,大于小于、if、for、模糊搜索、case when、choose

    Mybatis 常用條件語句,大于小于、if、for、模糊搜索、case when、choose

    目錄 大于小于 if 條件判斷? for循環(huán) LIKE?模糊搜索 case when choose選擇語句 前言-與正文無關(guān) ????????生活遠(yuǎn)不止眼前的苦勞與奔波,它還充滿了無數(shù)值得我們?nèi)ンw驗和珍惜的美好事物。在這個快節(jié)奏的世界中,我們往往容易陷入工作的漩渦,忘記了停下腳步,感受周圍的世

    2024年02月01日
    瀏覽(27)
  • mybatis的<choose>標(biāo)簽使用

    記錄 :418 場景 :使用MyBatis的choose/choose標(biāo)簽的when/when標(biāo)簽的test屬性,對入?yún)傩缘闹底龇莕ull(!=null)、非空(!=\\\'\\\')判斷,或者與常量做相等(==)或者不等判斷(!=)。 版本 :JDK 1.8,Spring?Boot 2.6.3,mybatis-3.5.9。 1.基礎(chǔ)知識 1.1MyBatis的標(biāo)簽 (1)查看MyBatis支持的標(biāo)簽 地址:http://mybatis.org/d

    2024年02月08日
    瀏覽(25)
  • mybatis的<sql>標(biāo)簽使用

    記錄 :421 場景 :使用MyBatis的sql/sql標(biāo)簽元素,把重復(fù)的SQL語句集中到sql標(biāo)簽,使用標(biāo)簽的id屬性指定唯一標(biāo)識。在insertupdatedeleteselect等標(biāo)簽中使用include/include標(biāo)簽引用sql/sql標(biāo)簽。 版本 :JDK 1.8,Spring?Boot 2.6.3,mybatis-3.5.9。 1.基礎(chǔ)知識 1.1MyBatis的標(biāo)簽 (1)查看MyBatis支持的標(biāo)簽 地址

    2024年01月22日
    瀏覽(25)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包