mybatis的<choose>标签使用

记录:418

场景:使用MyBatis的<choose></choose>标签的<when></when>标签的test属性,对入参属性的值做非null(!=null)、非空(!='')判断,或者与常量做相等(==)或者不等判断(!=)。

版本:JDK 1.8,Spring Boot 2.6.3,mybatis-3.5.9。

1.基础知识

1.1MyBatis的标签

(1)查看MyBatis支持的标签

地址:http://mybatis.org/dtd/mybatis-3-mapper.dtd

(2)查看标签使用

以<mapper></mapper>标签元素为例,在mybatis-3-mapper.dtd中如下:

<!ELEMENT mapper (cache-ref | cache | resultMap* | parameterMap* | sql* | insert* | update* | delete* | select* )+>
<!ATTLIST mapper
namespace CDATA #IMPLIED
>

<!ELEMENT mapper(...)+>,表示这是一个标签元素mapper.

(..| insert*| update* | delete* | select*),表示在mapper元素中可以嵌套使用的元素清单。

<!ATTLIST mapper>,表示这是一个元素标签的支持的属性。

1.2MyBatis的使用

(1)在application.yml配置文件配置mybatis映射的xml文件位置。

mybatis:
  mapper-locations: classpath*:mapper/**/*.xml

(2)创建一个Java接口。在接口中添加方法。

(3)创建一个Java接口映射的xml文件。在xml中使用<mapper></mapper>标签的namespace属性指定Java接口的全路径。Java接口和xml映射文件就完成了绑定关系。

(4)在<mapper></mapper>标签内,使用<insert><update><delete><select>等标签的id属性指定Java的方法名称。Java接口的方法和xml映射文件的<mapper></mapper>内部的标签就完成了绑定关系。

2.使用<choose></choose>标签元素

场景:<choose></choose>标签元素在<insert><update><delete><select>等标签元素内使用。

一般组合:<choose><when></when><otherwise></otherwise></choose>

一般组合:<choose><when></when><when></when></choose>

示例功能:示例使用<choose></choose>标签,根据不同条件组装不同查询的SQL。

2.1Java接口

@Repository
public interface Label02ChooseMapper {
  List<CityLabelPO> queryCity(CityLabelDTO cityLabelDTO);
}

2.2Java接口映射的xml文件

<?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.hub.example.mapper.Label02ChooseMapper">
  <select id="queryCity" parameterType="com.hub.example.domain.CityLabelDTO"
        resultType="com.hub.example.domain.CityLabelPO">
    select CITY_ID AS "cityId",
    <choose>
        <when test="flagColumn !=null and flagColumn !='' and flagColumn == '01' ">
            CITY_NAME AS "cityName",
            LAND_AREA AS "landArea",
            POPULATION AS "population",
            GROSS AS "gross",
            CITY_DESCRIBE AS "cityDescribe",
            DATA_YEAR AS "dataYear",
            UPDATE_TIME AS "updateTime"
        </when>
        <when test="flagColumn !=null and flagColumn !='' and flagColumn == '02' ">
            CITY_NAME AS "cityName",
            LAND_AREA AS "landArea"
        </when>
        <otherwise>
            CITY_NAME AS "cityName",
            LAND_AREA AS "landArea",
            POPULATION AS "population",
            GROSS AS "gross"
        </otherwise>
    </choose>
    from
    <choose>
        <when test="flagFrom !=null and flagFrom !='' and flagFrom == '01' ">
            t_city
        </when>
        <otherwise>
            t_city_01
        </otherwise>
    </choose>
    aa
    where
    <choose>
        <when test="cityId !=null and cityId !='' and flagWhere == '01' ">
            aa.CITY_ID = #{cityId}
        </when>
        <when test="cityName !=null and cityName !='' and flagWhere == '02' ">
            aa.CITY_NAME = #{cityName}
        </when>
    </choose>
  </select>
</mapper>

3.测试

3.1测试代码

@Slf4j
@RestController
@RequestMapping("/hub/example/cityLabel")
public class CityLabelController {
  @Autowired
  private Label02ChooseMapper label02ChooseMapper;
  @GetMapping("/load02")
  public Object load02() {
    log.info("测试开始...");
    // 示例一
    CityLabelDTO labelDTO = CityLabelDTO.builder()
            .cityId(1L).flagColumn("01")
            .flagFrom("01").flagWhere("01").build();
    List<CityLabelPO> labelPOList = label02ChooseMapper.queryCity(labelDTO);
    // 示例二
    labelDTO = CityLabelDTO.builder()
            .cityName("上海").flagColumn("02")
            .flagFrom("02").flagWhere("02").build();
    labelPOList = label02ChooseMapper.queryCity(labelDTO);
    log.info("测试结束...");
    return "执行成功";
  }
}

3.2测试请求

URL:http://127.0.0.1:18080/hub-example/hub/example/cityLabel/load02

3.3执行SQL

示例使用<choose></choose>标签后,根据不同条件组装不同查询的SQL,适配不同业务场景。

示例一:

SELECT
  CITY_ID AS "cityId",
  CITY_NAME AS "cityName",
  LAND_AREA AS "landArea",
  POPULATION AS "population",
  GROSS AS "gross",
  CITY_DESCRIBE AS "cityDescribe",
  DATA_YEAR AS "dataYear",
  UPDATE_TIME AS "updateTime"
FROM
  t_city aa
WHERE aa.CITY_ID = ?;

示例二:

SELECT
  CITY_ID AS "cityId",
  CITY_NAME AS "cityName",
  LAND_AREA AS "landArea"
FROM
  t_city_01 aa
WHERE aa.CITY_NAME = ?;

4.支撑

4.1实体对象

(1)封装结果对象CityLabelPO

@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class CityLabelPO {
  private Long cityId;
  private String cityName;
  private Double landArea;
  private Long population;
  private Double gross;
  private String cityDescribe;
  private String dataYear;
  private Date updateTime;
}

(2)封装参数CityLabelDTO

@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class CityLabelDTO {
  private Long cityId;
  private String cityName;
  private Double landArea;
  private Long population;
  private Double gross;
  private String cityDescribe;
  private String dataYear;
  private Date updateTime;
  // 标记查询的字段
  private String flagColumn;
  // 标记查询的表
  private String flagFrom;
  // 标记where条件
  private String flagWhere;
}

4.2建表语句

CREATE TABLE t_city (
  CITY_ID BIGINT(16) NOT NULL COMMENT '唯一标识',
  CITY_NAME VARCHAR(64) COLLATE utf8_bin NOT NULL COMMENT '城市名',
  LAND_AREA DOUBLE DEFAULT NULL COMMENT '城市面积',
  POPULATION BIGINT(16) DEFAULT NULL COMMENT '城市人口',
  GROSS DOUBLE DEFAULT NULL COMMENT '生产总值',
  CITY_DESCRIBE VARCHAR(512) COLLATE utf8_bin DEFAULT NULL COMMENT '城市描述',
  DATA_YEAR VARCHAR(16) COLLATE utf8_bin DEFAULT NULL COMMENT '数据年份',
  UPDATE_TIME DATETIME DEFAULT NULL COMMENT '更新时间'
) ENGINE=INNODB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='城市信息表';

以上,感谢。

2023年4月23日

  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
## Mybatis Generator配置详解 一、简介 mybatis-geneator是一款mybatis自动代码生成工具,可以通过配置,快速生成mapper和xml文件。 二、配置方法 在项目的pom文件中添加插件配置 ```java <plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.3.2</version> <configuration> <verbose>true</verbose> <overwrite>true</overwrite> </configuration> </plugin> ``` 在main的resource目录下创建generatorConfig.xml文件 ![在这里插入图片描述](https://img-blog.csdnimg.cn/20200323172307167.png) 配置文件中的内容如下,可根据需要自行修改 ```java <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE generatorConfiguration PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN" "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd"> <generatorConfiguration> <!-- 数据库驱动:选择你的本地硬盘上面的数据库驱动包--> <classPathEntry location="D:\Users\ZLZ\.m2\repository\mysql\mysql-connector-java\8.0.15\mysql-connector-java-8.0.15.jar"/> <context id="DB2Tables" targetRuntime="MyBatis3"> <commentGenerator> <property name="suppressDate" value="true"/> <!-- 是否去除自动生成的注释 true:是 : false:否 --> <property name="suppressAllComments" value="true"/> </commentGenerator> <!--数据库链接URL,用户名、密码 --> <jdbcConnection driverClass="com.mysql.cj.jdbc.Driver" connectionURL="jdbc:mysql://127.0.0.01:3306/shop? useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=UTC" userId="root" password="root"> </jdbcConnection> <javaTypeResolver> <property name="forceBigDecimals" value="false"/> </javaTypeResolver> <!-- 生成模型的包名和位置--> <javaModelGenerator targetPackage="com.example.shop.shop.domain" targetProject="src/main/java"> <property name="enableSubPackages" value="true"/> <property name="trimStrings" value="true"/> </javaModelGenerator> <!-- 生成映射文件的包名和位置--> <sqlMapGenerator targetPackage="mapper" targetProject="src/main/resources"> <property name="enableSubPackages" value="true"/> </sqlMapGenerator> <!-- 生成DAO的包名和位置--> <javaClientGenerator type="XMLMAPPER" targetPackage="com.example.shop.shop.dao" targetProject="src/main/java"> <property name="enableSubPackages" value="true"/> </javaClientGenerator> <!-- 要生成的表 tableName是数据库中的表名或视图名 domainObjectName是实体类名--> <table tableName="ad" domainObjectName="Ad" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"/> </context> </generatorConfiguration>
<> 标签MyBatis 中的一种条件判断标签,类似于 Java 中的 switch 语句,可以根据不同的条件匹配不同的 SQL 语句。它可以包含多个 <when> 标签和一个可选的 <otherwise> 标签。 <choose> 标签的语法如下: ``` <choose> <when test="condition1"> <!-- SQL statement 1 --> </when> <when test="condition2"> <!-- SQL statement 2 --> </when> <when test="condition3"> <!-- SQL statement 3 --> </when> <otherwise> <!-- default SQL statement --> </otherwise> </choose> ``` 其中,test 属性表示条件表达式,满足条件表达式的 SQL 语句会被执行,否则执行 <otherwise> 标签中的 SQL 语句。可以包含多个 <when> 标签,只有第一个满足条件的 <when> 标签中的 SQL 语句会被执行,其他的 <when> 标签会被忽略。 例如,以下是一个根据不同情况查询员工信息的 SQL 语句: ``` <select id="getEmployee" parameterType="int" resultType="Employee"> SELECT * FROM employee <where> <choose> <when test="deptId != null"> AND dept_id = #{deptId} </when> <when test="jobTitle != null"> AND job_title = #{jobTitle} </when> <otherwise> AND employee_id = #{employeeId} </otherwise> </choose> </where> </select> ``` 以上 SQL 语句中,使用了 <choose> 标签来判断查询条件,当传入参数中的 deptId 不为空时,执行 AND dept_id = #{deptId} 的 SQL 语句;当传入参数中的 jobTitle 不为空时,执行 AND job_title = #{jobTitle} 的 SQL 语句;否则执行 AND employee_id = #{employeeId} 的 SQL 语句。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值