Day06-使用Excel导入课程分类信息后端-p97、98

poi

${poi.version}

org.apache.poi

poi-ooxml

${poi.version}

二、业务处理

=====================================================================

2.1、创建课程分类表edu_subject


在这里插入图片描述

#sql语句

CREATE TABLE edu_subject (

id char(19) NOT NULL COMMENT ‘课程类别ID’,

title varchar(10) NOT NULL COMMENT ‘类别名称’,

parent_id char(19) NOT NULL DEFAULT ‘0’ COMMENT ‘父ID’,

sort int(10) unsigned NOT NULL DEFAULT ‘0’ COMMENT ‘排序字段’,

gmt_create datetime NOT NULL COMMENT ‘创建时间’,

gmt_modified datetime NOT NULL COMMENT ‘更新时间’,

PRIMARY KEY (id),

KEY idx_parent_id (parent_id)

) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 ROW_FORMAT=COMPACT COMMENT=‘课程科目’

2.2、代码生成器生成后端代码


利用mybatis-plus代码生成器根据数据库中的表生成控制层,业务层,持久层代码。

在这里插入图片描述注意修改代码,在修改4中改成对应的表:

在这里插入图片描述

package com.nonglin.demo;

import com.baomidou.mybatisplus.annotation.DbType;

import com.baomidou.mybatisplus.annotation.IdType;

import com.baomidou.mybatisplus.generator.AutoGenerator;

import com.baomidou.mybatisplus.generator.config.DataSourceConfig;

import com.baomidou.mybatisplus.generator.config.GlobalConfig;

import com.baomidou.mybatisplus.generator.config.PackageConfig;

import com.baomidou.mybatisplus.generator.config.StrategyConfig;

import com.baomidou.mybatisplus.generator.config.rules.DateType;

import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;

import org.junit.Test;

/**

  • @author

  • @since 2021/2/21

*/

public class CodeGenerator {

@Test

public void run() {

// 1、创建代码生成器

AutoGenerator mpg = new AutoGenerator();

// 2、全局配置

GlobalConfig gc = new GlobalConfig();

String projectPath = System.getProperty(“user.dir”);

//修改1、projectPath:替换代码生成的绝对路径

gc.setOutputDir(“E:\workspaces\IDEA\SpringBoot\cui_parent\service\service_edu” + “/src/main/java”);

gc.setAuthor(“Lenovo”);//生成代码作者的名字

gc.setOpen(false); //生成后是否打开资源管理器

gc.setFileOverride(false); //重新生成时文件是否覆盖

gc.setServiceName(“%sService”); //去掉Service接口的首字母I

gc.setIdType(IdType.ID_WORKER_STR); //主键策略

gc.setDateType(DateType.ONLY_DATE);//定义生成的实体类中日期类型

gc.setSwagger2(true);//开启Swagger2模式

mpg.setGlobalConfig(gc);

// 3、数据源配置

DataSourceConfig dsc = new DataSourceConfig();

//修改2、

dsc.setUrl(“jdbc:mysql://localhost:3306/guli?serverTimezone=GMT%2B8”);

dsc.setDriverName(“com.mysql.cj.jdbc.Driver”);

dsc.setUsername(“root”);

dsc.setPassword(“root”);

dsc.setDbType(DbType.MYSQL);

mpg.setDataSource(dsc);

// 4、包配置

PackageConfig pc = new PackageConfig();

//修改3、

//会生成com.nonglin.eduservice包

pc.setModuleName(“eduservice”); //模块名

pc.setParent(“com.nonglin”);

pc.setController(“controller”);//会生成com.nonglin.eduservice.controller包

pc.setEntity(“entity”);//会生成com.nonglin.eduservice.entity包

pc.setService(“service”);//会生成com.nonglin.eduservice.service包

pc.setMapper(“mapper”);//会生成com.nonglin.eduservice.mapper包

mpg.setPackageInfo(pc);

// 5、策略配置

StrategyConfig strategy = new StrategyConfig();

//修改4、

strategy.setInclude(“edu_subject”);//对应到数据库中的表

strategy.setNaming(NamingStrategy.underline_to_camel);//数据库表映射到实体的命名策略

strategy.setTablePrefix(pc.getModuleName() + “_”); //生成实体时去掉表前缀

strategy.setColumnNaming(NamingStrategy.underline_to_camel);//数据库表字段映射到实体的命名策略

strategy.setEntityLombokModel(true); // lombok 模型 @Accessors(chain = true) setter链式操作

strategy.setRestControllerStyle(true); //restful api风格控制器

strategy.setControllerMappingHyphenStyle(true); //url中驼峰转连字符

mpg.setStrategy(strategy);

// 6、执行

mpg.execute();

}

}

2.3、创建excel文件对应的实体类


01.xlsx文件

在这里插入图片描述

excel对应的实体类

在这里插入图片描述

package com.nonglin.eduservice.entity.excel;

import com.alibaba.excel.annotation.ExcelProperty;

import lombok.Data;

/**

  • @Description :

  • @Author :lenovo

  • @Date :2021/3/8 10:18

*/

@Data

public class SubjectData {

@ExcelProperty(index = 0)

private String oneSubjectName;

@ExcelProperty(index = 1)

private String twoSubjectName;

}

2.4、编写控制层代码


在这里插入图片描述

package com.nonglin.eduservice.controller;

import com.nonglin.commonutils.R;

import com.nonglin.eduservice.service.EduSubjectService;

import io.swagger.annotations.Api;

import io.swagger.annotations.ApiOperation;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.web.bind.annotation.CrossOrigin;

import org.springframework.web.bind.annotation.PostMapping;

import org.springframework.web.bind.annotation.RequestMapping;

import org.springframework.web.bind.annotation.RestController;

import org.springframework.web.multipart.MultipartFile;

/**

  • 课程科目 前端控制器

  • @author Lenovo

  • @since 2021-03-08

*/

@Api(description=“课程管理”)

@RestController

@RequestMapping(“/eduservice/subject”)

@CrossOrigin

public class EduSubjectController {

@Autowired

private EduSubjectService subjectService;

//添加课程分类

//获取上传过来文件,把文件内容读取出来

@ApiOperation(value = “Excel批量导入课程信息”)

@PostMapping(“addSubject”)

public R addSubject(MultipartFile file) {

//上传过来excel文件

subjectService.saveSubject(file,subjectService);

return R.ok();

}

}

2.5、编写业务层代码


2.5.1、接口代码

在这里插入图片描述

package com.nonglin.eduservice.service;

import com.nonglin.eduservice.entity.EduSubject;

import com.baomidou.mybatisplus.extension.service.IService;

import org.springframework.web.multipart.MultipartFile;

/**

  • 课程科目 服务类

  • @author Lenovo

  • @since 2021-03-08

*/

public interface EduSubjectService extends IService {

//添加课程分类

void saveSubject(MultipartFile file,EduSubjectService subjectService);

}

2.5.2、实现类代码

在这里插入图片描述

package com.nonglin.eduservice.service.impl;

import com.alibaba.excel.EasyExcel;

import com.nonglin.eduservice.Listener.SubjectExcelListener;

import com.nonglin.eduservice.entity.EduSubject;

import com.nonglin.eduservice.entity.excel.SubjectData;

import com.nonglin.eduservice.mapper.EduSubjectMapper;

import com.nonglin.eduservice.service.EduSubjectService;

import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;

import org.springframework.stereotype.Service;

import org.springframework.web.multipart.MultipartFile;

import java.io.InputStream;

/**

  • 课程科目 服务实现类

  • @author Lenovo

  • @since 2021-03-08

*/

@Service

public class EduSubjectServiceImpl extends ServiceImpl<EduSubjectMapper, EduSubject> implements EduSubjectService {

//添加课程分类

@Override

public void saveSubject(MultipartFile file,EduSubjectService subjectService) {

try {

//文件输入流

InputStream in = file.getInputStream();

//调用方法进行读取
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

今天的文章可谓是积蓄了我这几年来的应聘和面试经历总结出来的经验,干货满满呀!如果你能够一直坚持看到这儿,那么首先我还是十分佩服你的毅力的。不过光是看完而不去付出行动,或者直接进入你的收藏夹里吃灰,那么我写这篇文章就没多大意义了。所以看完之后,还是多多行动起来吧!

可以非常负责地说,如果你能够坚持把我上面列举的内容都一个不拉地看完并且全部消化为自己的知识的话,那么你就至少已经达到了中级开发工程师以上的水平,进入大厂技术这块是基本没有什么问题的了。

1713479913722)]

[外链图片转存中…(img-IIqjg5Jk-1713479913723)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

[外链图片转存中…(img-XJQYram5-1713479913723)]

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

[外链图片转存中…(img-0QFXPkCq-1713479913723)]

最后

今天的文章可谓是积蓄了我这几年来的应聘和面试经历总结出来的经验,干货满满呀!如果你能够一直坚持看到这儿,那么首先我还是十分佩服你的毅力的。不过光是看完而不去付出行动,或者直接进入你的收藏夹里吃灰,那么我写这篇文章就没多大意义了。所以看完之后,还是多多行动起来吧!

可以非常负责地说,如果你能够坚持把我上面列举的内容都一个不拉地看完并且全部消化为自己的知识的话,那么你就至少已经达到了中级开发工程师以上的水平,进入大厂技术这块是基本没有什么问题的了。

资料领取方式:戳这里前往免费领取

 Excelにてスケジュールを管理する時、いろんな手作業が必要となってしまいます。  Excel版ガントチャートは、VBAを利用して、いろんな時間がかかる手作業を自動で完成できるアプリです。  ・WBSの作成はタスク、担当、工数のみ指定すればOK、ほかはすべて自動化(自動リスケモードがON時)  ・プロジェクトの開始・終了日を指定するだけで、カレンダーを自動描画(休出・祝日も表示可能)  ・カレンダー単位を設定可能(日単位、週単位など)  ・タスクの進捗状況を自動監視(進捗遅れ、本日開始、本日終了)  ・週次・月次の周期タスクを指定可能  ・担当者毎の個人カレンダーを指定可能  ・担当者毎の生産性、参画日・リリース予定日、単価(人日)を指定可能  ・(複数)選択しているタスクの位置を自動調整可能(左へ、右へ、上へ、下へ)  ・(複数)選択しているタスクの予定日を一括調整可能  ・各担当者の作業分担を確認し易いため、指定担当者だけのタスク情報を表示可能  ・各タスク間の依存関係を指定可能(FS,SS,SF,FF)   かつ、各タスク間の依存関係指定に不備があれば、自動チェックし、一目瞭然  ・各タスクの進捗状況により、イナズマ線を自動作成可能  ・WBS全体を確認し易いため、担当者毎のガントチャート情報を色分けて表示可能  ・ワークロード分析結果を自動作成(日別、週別、月別)  ・タスク別のEVM分析(タスクの進捗により、いつ完了すべきか自動計算)  ・プロジェクト全体のEVM人月・金額分析(日別、週別、月別)  ・WBSシートにはマクロないので、別ブックにコピーし、お客様・他人に送付するのはOK   ★フリーバージョン制限:最大30タスクまで(他制限なし)★
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值