2024年Web前端最新Day06-使用Excel导入课程分类信息后端-p97、98,2024年最新字节跳动面试难吗

最后

我可以将最近整理的前端面试题分享出来,其中包含HTML、CSS、JavaScript、服务端与网络、Vue、浏览器、数据结构与算法等等,还在持续整理更新中,希望大家都能找到心仪的工作。

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

篇幅有限,仅展示部分截图:

com.alibaba

easyexcel

2.1.1

org.apache.poi

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、实现类代码

在这里插入图片描述

总结一下

面试前要精心做好准备,简历上写的知识点和原理都需要准备好,项目上多想想难点和亮点,这是面试时能和别人不一样的地方。

还有就是表现出自己的谦虚好学,以及对于未来持续进阶的规划,企业招人更偏爱稳定的人。

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

万事开头难,但是程序员这一条路坚持几年后发展空间还是非常大的,一切重在坚持。

为了帮助大家更好更高效的准备面试,特别整理了《前端工程师面试手册》电子稿文件。

前端面试题汇总

JavaScript

性能

linux

前端资料汇总

前端工程师岗位缺口一直很大,符合岗位要求的人越来越少,所以学习前端的小伙伴要注意了,一定要把技能学到扎实,做有含金量的项目,这样在找工作的时候无论遇到什么情况,问题都不会大。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值