基于Java SSM實(shí)現(xiàn)Excel數(shù)據(jù)批量導(dǎo)入
導(dǎo)入Maven依賴(lài)
<dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>${easyexcel.version}</version> </dependency>
Mapper及映射文件
UserMapper.java
@Mapper public interface UserMapper { int batchInsert(@Param("list") List<User> list); }
UserMapper.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.hc.mapper.UserMapper"> <resultMap id="BaseResultMap" type="com.hc.domain.User"> <!--@mbg.generated--> <!--@Table tb_user--> <id column="id" jdbcType="BIGINT" property="id" /> <result column="nickname" jdbcType="VARCHAR" property="nickname" /> <result column="avatar" jdbcType="VARCHAR" property="avatar" /> <result column="account" jdbcType="VARCHAR" property="account" /> <result column="password" jdbcType="VARCHAR" property="password" /> <result column="gender" jdbcType="TINYINT" property="gender" /> <result column="tel" jdbcType="VARCHAR" property="tel" /> <result column="email" jdbcType="VARCHAR" property="email" /> <result column="qq" jdbcType="VARCHAR" property="qq" /> <result column="wechat" jdbcType="VARCHAR" property="wechat" /> <result column="salt" jdbcType="VARCHAR" property="salt" /> <result column="info" jdbcType="VARCHAR" property="info" /> <result column="status" jdbcType="TINYINT" property="status" /> <result column="create_time" jdbcType="TIMESTAMP" property="createTime" /> <result column="update_time" jdbcType="TIMESTAMP" property="updateTime" /> </resultMap> <sql id="Base_Column_List"> <!--@mbg.generated--> id, nickname, avatar, account, `password`, gender, tel, email, qq, wechat, salt, info, `status`, create_time, update_time </sql> <insert id="batchInsert" keyColumn="id" keyProperty="id" parameterType="map" useGeneratedKeys="true"> <!--@mbg.generated--> insert into tb_user (nickname, avatar, account, `password`, gender, tel, email, qq, wechat, salt, info, `status`, create_time, update_time) values <foreach collection="list" item="item" separator=","> (#{item.nickname,jdbcType=VARCHAR}, #{item.avatar,jdbcType=VARCHAR}, #{item.account,jdbcType=VARCHAR}, #{item.password,jdbcType=VARCHAR}, #{item.gender,jdbcType=TINYINT}, #{item.tel,jdbcType=VARCHAR}, #{item.email,jdbcType=VARCHAR}, #{item.qq,jdbcType=VARCHAR}, #{item.wechat,jdbcType=VARCHAR}, #{item.salt,jdbcType=VARCHAR}, #{item.info,jdbcType=VARCHAR}, #{item.status,jdbcType=TINYINT}, #{item.createTime,jdbcType=TIMESTAMP}, #{item.updateTime,jdbcType=TIMESTAMP}) </foreach> </insert> </mapper>
Excel監(jiān)聽(tīng)器
@Log4j2 @Service public class UserExcelListener extends AnalysisEventListener<User> { @Resource private UserMapper userMapper; /** * 批處理閾值 */ private static final int BATCH_COUNT = 250; @Getter List<User> list = new ArrayList<>(BATCH_COUNT); @Override public void invoke(User user, AnalysisContext analysisContext) { //逐行讀取數(shù)據(jù) log.info("********** 解析到一條數(shù)據(jù):{}", JSON.toJSONString(user)); list.add(user); if (list.size() >= BATCH_COUNT) { System.out.println("已經(jīng)解析"+list.size()+"條數(shù)據(jù)"); //每250條,往數(shù)據(jù)庫(kù)中存一次 int batchInsertRes = userMapper.batchInsert(list); System.out.println(batchInsertRes); list.clear(); } } @Override public void doAfterAllAnalysed(AnalysisContext analysisContext) { log.info("**********所有數(shù)據(jù)解析完成!"); } }
測(cè)試
@ExtendWith(SpringExtension.class)
@ContextConfiguration("/applicationContext.xml")
public class ExcelUtilTest {
@Resource
private UserExcelListener userExcelListener;
@Test
void userListener(){
EasyExcel.read("E:\\Projects\\WorksDisplay\\data\\users.xlsx", User.class, userExcelListener)
.sheet()
.doRead();
}
}
到此這篇關(guān)于基于Java SSM實(shí)現(xiàn)Excel數(shù)據(jù)批量導(dǎo)入的文章就介紹到這了,更多相關(guān)Java? Excel數(shù)據(jù)批量導(dǎo)入內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Java通過(guò)SSM完成水果商城批發(fā)平臺(tái)流程
- Java開(kāi)發(fā)之ssm三大框架整合
- java ssm框架的controller實(shí)現(xiàn)向頁(yè)面?zhèn)鬟f參數(shù)
- 基于Java+SSM實(shí)現(xiàn)電影院購(gòu)票系統(tǒng)
- 基于Java SSM實(shí)現(xiàn)在線點(diǎn)餐系統(tǒng)
- 基于Java SSM框架實(shí)現(xiàn)簡(jiǎn)易的評(píng)教系統(tǒng)
- 基于Java SSM的健康管理小程序的實(shí)現(xiàn)
- Java SMM框架關(guān)聯(lián)關(guān)系映射示例講解
相關(guān)文章
Java17中record替代Lombok部分功能使用場(chǎng)景探究
這篇文章主要介紹了使用Java17中的record替代Lombok的部分功能,本文來(lái)為大家小小的總結(jié)下,我們可以在哪些地方,利用record來(lái)替換Lombok2024-01-01SpringBoot集成Validation參數(shù)校驗(yàn)
這篇文章主要為大家詳細(xì)介紹了SpringBoot集成Validation參數(shù)校驗(yàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01Java 采用反射獲取class屬性值的實(shí)現(xiàn)代碼
以下是對(duì)在Java中采用反射獲取class屬性值的實(shí)現(xiàn)代碼進(jìn)行了分析介紹,需要的朋友可以過(guò)來(lái)參考下2013-08-08mybatis中實(shí)現(xiàn)讓返回值與bean中字段相匹配
這篇文章主要介紹了mybatis中實(shí)現(xiàn)讓返回值與bean中字段相匹配,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-10-10分析java并發(fā)中的wait notify notifyAll
一個(gè)線程修改一個(gè)對(duì)象的值,而另一個(gè)線程則感知到了變化,然后進(jìn)行相應(yīng)的操作,這就是wait()、notify()和notifyAll()方法的本質(zhì)。本文將詳細(xì)來(lái)介紹它們概念實(shí)現(xiàn)以及區(qū)別2021-06-06Debian配置JDK1.7 與Linux Java Helloworld
這篇文章主要介紹了Debian配置JDK1.7 與Linux Java Helloworld 的相關(guān)資料,需要的朋友可以參考下2016-06-06Java實(shí)現(xiàn)將文件或者文件夾壓縮成zip的詳細(xì)代碼
這篇文章主要介紹了Java實(shí)現(xiàn)將文件或者文件夾壓縮成zip的詳細(xì)代碼,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-11-11java使用list實(shí)現(xiàn)數(shù)據(jù)庫(kù)的like功能
這篇文章主要介紹了java使用list實(shí)現(xiàn)數(shù)據(jù)庫(kù)的like功能,需要的朋友可以參考下2014-04-04Mybatis-Plus自動(dòng)填充更新操作相關(guān)字段的實(shí)現(xiàn)
數(shù)據(jù)庫(kù)表中應(yīng)該都要有create_time、update_time字段;那么在開(kāi)發(fā)中,對(duì)于這些共有字段的處理應(yīng)該要進(jìn)行統(tǒng)一,這樣就可以簡(jiǎn)化我們的開(kāi)發(fā)過(guò)程。那么本文就對(duì)Mybatis-Plus中的字段自動(dòng)填充進(jìn)行記錄2021-11-11