添加依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.1.4</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<!-- poi 导入导出 Excel-->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.17</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.17</version>
</dependency>
将excel中的表格数据批量插入到数据库中 使用测试数据

代码已上传
https://gitee.com/zhanghu9080/excel-batch-insert-data
mybaits的批量插入
xxxMapper.xml
<insert id="saveAll" parameterType="com.cn.demo.pojo.Excel">
insert into text (id,username,email,password,role) values
<foreach collection="list" item="excels" index= "index" separator =",">
(#{excels.id},#{excels.username},#{excels.email},#{excels.password},#{excels.role})
</foreach>
</insert>
xxxMapper.java(部分)
@Mapper
public interface ExcelReposiory {
int saveAll(List excels);
}
使用批量插入执行的SQL语句应该等价于:
insert into text (id,username,email,password,role) values (?,?,?,?,?),(?,?,?,?,?),(?,?,?,?,?),(?,?,?,?,?)
对于foreach标签的解释参考网上的资料,具体如下:
foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合。
foreach元素的属性主要有 item,index,collection,open,separator,close。
item表示集合中每一个元素进行迭代时的别名,index指定一个名字,用于表示在迭代过程中,每次迭代到的位置,open表示该语句以什么开始,separator表示在每次进行迭代之间以什么符号作为分隔 符,close表示以什么结束,在使用foreach的时候最关键的也是最容易出错的就是collection属性,该属性是必须指定的,但是在不同情况 下,该属性的值是不一样的,主要有一下3种情况:
1.如果传入的是单参数且参数类型是一个List的时候,collection属性值为list
2.如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array
3.如果传入的参数是多个的时候,我们就需要把它们封装成一个Map了,当然单参数也可以封装成map
本文介绍了如何使用Spring Boot、MyBatis和Apache POI库从Excel文件批量导入数据并将其插入到数据库中。示例代码展示了在Mapper XML文件中配置批量插入的foreach标签,以及在Mapper接口中定义相应的保存方法。此外,还提供了关键的依赖项,包括Spring Boot Starter、MyBatis Starter、MySQL连接器和POI库。
3667

被折叠的 条评论
为什么被折叠?



