mybatis的<foreach>标签使用

这篇具有很好参考价值的文章主要介绍了mybatis的<foreach>标签使用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

记录:419

场景:使用MyBatis的<foreach></foreach>标签的循环遍历List类型的入参。使用collection属性指定List,item指定List中存放的对象,separator指定分割符号,open指定开始字符,close指定结束字符。

版本: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.使用<foreach></foreach>标签元素

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

示例功能:示例使用<foreach></foreach>标签,在<insert><update><delete><select>标签内遍历输入的List类型入参。

2.1Java接口

@Repository
public interface Label03ForeachMapper {
  List<CityLabelPO> queryCity(List<Long> paraList);
  int insertCity(List<CityLabelPO> cityList);
  int insertCityUnionAll(List<CityLabelPO> cityList);
  int updateCity(List<CityLabelPO> cityList);
  int deleteCity(List<CityLabelPO> cityList);
}

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.Label03ForeachMapper">
  <!--  1.查询时,使用<foreach></foreach>标签-->
  <select id="queryCity" resultType="com.hub.example.domain.CityLabelPO">
      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
      WHERE CITY_ID IN
      <foreach collection="list" item="cityId" open="(" separator="," close=")">
          #{cityId}
      </foreach>
  </select>
  <!--  2.1插入时,使用<foreach></foreach>标签,使用逗号分割-->
  <insert id="insertCity" parameterType="java.util.List">
      insert into t_city_01 (CITY_ID,
      CITY_NAME,
      LAND_AREA,
      POPULATION,
      GROSS,
      CITY_DESCRIBE,
      DATA_YEAR,
      UPDATE_TIME)
      values
      <foreach collection="list" item="cityPO" open="" separator="," close="">
          (#{cityPO.cityId},
          #{cityPO.cityName},
          #{cityPO.landArea},
          #{cityPO.population},
          #{cityPO.gross},
          #{cityPO.cityDescribe},
          #{cityPO.dataYear},
          #{cityPO.updateTime})
      </foreach>
  </insert>
  <!--  2.2插入时,使用<foreach></foreach>标签,使用union all分割-->
  <insert id="insertCityUnionAll" parameterType="java.util.List">
      insert into t_city_01 (CITY_ID,
      CITY_NAME,
      LAND_AREA,
      POPULATION,
      GROSS,
      CITY_DESCRIBE,
      DATA_YEAR,
      UPDATE_TIME)
      <foreach collection="list" item="cityPO" open="" separator="UNION ALL" close="">
          select
          #{cityPO.cityId},
          #{cityPO.cityName},
          #{cityPO.landArea},
          #{cityPO.population},
          #{cityPO.gross},
          #{cityPO.cityDescribe},
          #{cityPO.dataYear},
          #{cityPO.updateTime}
          from dual
      </foreach>
  </insert>
  <!--  3.更新时,使用<foreach></foreach>标签-->
  <update id="updateCity" parameterType="java.util.List">
      update
      t_city_01
      set CITY_DESCRIBE='杭州是一个发达城市'
      WHERE CITY_ID IN
      <foreach collection="list" item="cityPO" open="(" separator="," close=")">
          #{cityPO.cityId}
      </foreach>
  </update>
  <!--  4.删除时,使用<foreach></foreach>标签-->
  <delete id="deleteCity" parameterType="java.util.List">
      delete from t_city_01 where 1=1
      <if test="list.size()>0">
          AND CITY_ID IN
          <foreach collection="list" item="cityPO" open="(" separator="," close=")">
              #{cityPO.cityId}
          </foreach>
      </if>
  </delete>
</mapper>

3.测试

3.1测试代码

@Slf4j
@RestController
@RequestMapping("/hub/example/cityLabel")
public class CityLabelController {
  @Autowired
  private Label03ForeachMapper label03ForeachMapper;
  @GetMapping("/load03")
  public Object load03() {
    log.info("测试开始...");
    // 生成查询参数
    List<Long> paraList = Arrays.asList(1L, 2L, 3L);
    // 1.查询时,使用<foreach></foreach>标签
    List<CityLabelPO> list01 = label03ForeachMapper.queryCity(paraList);
    // 2.1插入时,使用<foreach></foreach>标签,使用逗号分割
    label03ForeachMapper.insertCity(list01);
    // 2.2插入时,使用<foreach></foreach>标签,使用union all分割
    paraList = Arrays.asList(4L, 5L, 6L);
    List<CityLabelPO> list02 = label03ForeachMapper.queryCity(paraList);
    label03ForeachMapper.insertCityUnionAll(list02);
    // 3.更新时,使用<foreach></foreach>标签
    label03ForeachMapper.updateCity(list01);
    // 4.删除时,使用<foreach></foreach>标签
    label03ForeachMapper.deleteCity(list01);
    log.info("测试结束...");
    return "执行成功";
  }
}

3.2测试请求

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

3.3执行SQL

示例使用<foreach></foreach>标签后,遍历List类型入参,从具体对象中取值。

示例一,查询时,使用<foreach></foreach>标签。

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
WHERE CITY_ID IN (?, ?, ?)

示例二,插入时,使用<foreach></foreach>标签,使用逗号分割。

INSERT INTO t_city_01 (
  CITY_ID,
  CITY_NAME,
  LAND_AREA,
  POPULATION,
  GROSS,
  CITY_DESCRIBE,
  DATA_YEAR,
  UPDATE_TIME
)
VALUES
  (?, ?, ?, ?, ?, ?, ?, ?),
  (?, ?, ?, ?, ?, ?, ?, ?),
  (?, ?, ?, ?, ?, ?, ?, ?)

示例三,插入时,使用<foreach></foreach>标签,使用union all分割。

INSERT INTO t_city_01 (CITY_ID, CITY_NAME, LAND_AREA, 
 POPULATION, GROSS, CITY_DESCRIBE, DATA_YEAR, UPDATE_TIME) 
SELECT ?, ?, ?, ?, ?, ?, ?, ? FROM DUAL 
UNION ALL 
SELECT ?, ?, ?, ?, ?, ?, ?, ? FROM DUAL 
UNION ALL 
SELECT ?, ?, ?, ?, ?, ?, ?, ? FROM DUAL

示例四,更新时,使用<foreach></foreach>标签。

UPDATE
  t_city_01
SET
  CITY_DESCRIBE = '杭州是一个发达城市'
WHERE CITY_ID IN (?, ?, ?)

示例五,删除时,使用<foreach></foreach>标签。

DELETE
FROM
  t_city_01
WHERE 1 = 1
  AND CITY_ID IN (?, ?, ?)

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;
}

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日文章来源地址https://www.toymoban.com/news/detail-423483.html

到了这里,关于mybatis的<foreach>标签使用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 分析ORACLE批量更新中的ORA-00911错误:MyBatis <foreach> 场景与解决方案

            在日常的Java开发过程中,尤其是当我们在使用MyBatis作为持久层框架进行Oracle数据库操作时,批量更新数据是非常常见的需求。然而,在利用MyBatis的 foreach 标签遍历集合参数动态构造SQL更新语句时,有时会遭遇ORA-00911: invalid character错误。这种错误表明在提交给O

    2024年04月23日
    浏览(29)
  • 在Mybatis中写动态sql这些标签:if、where、set、trim、foreach、choose的作用是什么,怎么用?

    在 MyBatis 中,您可以使用动态 SQL 标签来构建灵活的 SQL 查询,以根据不同的条件生成不同的查询语句。以下是这些标签的作用和用法: 1. **`if` 标签:** 用于根据某个条件动态地包含或排除 SQL 片段,test:可以写条件。    示例用法:        ```xml    select id=\\\"getUserList\\\" param

    2024年02月11日
    浏览(34)
  • MyBatis批处理,使用foreach

    测试代码: 批量插入数据的局限性: 无法获取插入数据的id 批量生成的SQL太长,可能会被服务器拒绝 测试代码

    2024年02月07日
    浏览(27)
  • 【mybatis】mapper.xml中foreach的用法,含批量查询、插入、修改、删除方法的使用

    一、xml文件中foreach的主要属性 foreach元素的属性主要有 collection,item,index,separator,open,close。 collection: 表示集合,数据源 item :表示集合中的每一个元素 index :用于表示在迭代过程中,每次迭代到的位置 separator :表示在迭代时数据以什么符号作为分隔符 open :表示该语

    2024年02月12日
    浏览(30)
  • mybatis trim标签使用详解

    mybatis的trim标签一般用于去除sql语句中多余的and,逗号,或者给sql语句前拼接 “where“、“set“以及“values(“ 等前缀,或者添加“)“等后缀,可用于选择性插入、更新、删除或者条件查询等操作。 以下是trim标签中涉及到的属性: prefix=添加前缀 suffix=添加后缀 prefix

    2024年02月06日
    浏览(38)
  • 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/d

    2024年02月08日
    浏览(29)
  • mybatis的<sql>标签使用

    记录 :421 场景 :使用MyBatis的sql/sql标签元素,把重复的SQL语句集中到sql标签,使用标签的id属性指定唯一标识。在insertupdatedeleteselect等标签中使用include/include标签引用sql/sql标签。 版本 :JDK 1.8,Spring Boot 2.6.3,mybatis-3.5.9。 1.基础知识 1.1MyBatis的标签 (1)查看MyBatis支持的标签 地址

    2024年01月22日
    浏览(27)
  • MyBatis-动态SQL-foreach

    目录 ``标签有以下常用属性: 小结 `foreach`标签有以下常用属性: `collection`:指定要迭代的集合或数组的参数名( 遍历的对象 )。 `item`:指定在迭代过程中的每个元素的别名( 遍历出来的元素 )。 `index`:指定迭代过程中的每个元素的索引值。 `open`:指定循环开始的字符

    2024年02月14日
    浏览(26)
  • Mybatis中where标签和if标签结合使用说明

    由于不小心将 and 或者 or 写在了语句后面,导致mybatis无法自主判别,这种问题在新上手的同学中很是常见。下面我们探讨一下,在哪些情况下Mybatis无法判断动态SQL语句中的 and 或者 or 。 select筛选出视图对象的参数,用于给前端返回页面参数使用。 以下代码格式是正确,我们

    2023年04月08日
    浏览(26)
  • MyBatis 动态SQL的标签有哪些?如何使用?

    目录 1. MyBatis 动态SQL标签有什么用? 2. if 标签 3. where 标签 4. trim 标签 5. choose,when,otherwise 6. foreach 1. MyBatis 动态SQL标签有什么用? 我来说一个场景大家就明白了,如下图,大家应该在铁路12306上买过火车票吧,可以看到,我们在选票的时候可以对车做很多种选择和筛选,系

    2024年02月11日
    浏览(26)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包