Springbooot实现Excel数据导入数据库

一、pom.xml 加入依赖

<!--        poi  hutool-->
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>4.1.2</version>
        </dependency>
        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>5.7.20</version>
        </dependency>

二、userMapper,批量添加  

        由于id和creatTime自动添加数据  所以省略

<!--    Integer addUsers(List<User> users);-->
        <insert id="addUsers">

        insert into sys_user(username, password, nickname, email, phone, address, avater)

            VALUES

            <foreach collection="list" item="user" separator="," >

                (#{user.username},#{user.password},#{user.nickname},#{user.email},#{user.phone},#{user.address},#{user.avater})

            </foreach>

        </insert>

三、controller 

//导入Excel
    @PostMapping("import")
    public Integer importExcel(MultipartFile file) throws IOException {

        InputStream is = file.getInputStream();
        ExcelReader reader = ExcelUtil.getReader(is);
        List<User> list = reader.readAll(User.class);
        Integer integer = userService.insertUsers(list);

        return integer;
    }

user实体类,使用@Alias注解  导入导出时  excel表头可以中文 



import cn.hutool.core.annotation.Alias;
import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.Data;

/**
 * @author 27164
 * @version 1.0
 * @description: TODO
 * @date 2023/9/23 10:34
 */

@Data
public class User {

    @Alias("id")
    private Integer id;
    @Alias("用户名")
    private String username;
    @Alias("密码")
    private String password;
    @Alias("昵称")
    private String nickname;
    @Alias("邮箱")
    private String email;
    @Alias("手机")
    private String phone;
    @Alias("地址")
    private String address;
    @Alias("创建时间")
    @JsonFormat(pattern = "yyyy年MM月dd日 HH时mm分ss秒")
    private String creatTime;
    @Alias("头像")
    private String avater;
}

四、对应表数据

五、字段

六、postman测试

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值