目录

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

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

最后

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

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

https://i-blog.csdnimg.cn/blog_migrate/1642d9fa8ecd434fc373c383be6ef7f0.png

https://i-blog.csdnimg.cn/blog_migrate/50f9a3e2255bf75dd9e00b48451d6a18.png

https://i-blog.csdnimg.cn/blog_migrate/bd7e0e76ba7b5232790cc9ae9bc27fef.png

com.alibaba

easyexcel

2.1.1

org.apache.poi

poi

${poi.version}

org.apache.poi

poi-ooxml

${poi.version}

二、业务处理

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

2.1、创建课程分类表edu_subject


https://i-blog.csdnimg.cn/blog_migrate/70c69186c1768fbba8fef21d821f3fae.png

#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代码生成器根据数据库中的表生成控制层,业务层,持久层代码。

https://i-blog.csdnimg.cn/blog_migrate/23afdf259ce2fc2568849f9bd17e526e.png 注意修改代码,在修改4中改成对应的表:

https://i-blog.csdnimg.cn/blog_migrate/7e50129abbed308b5d78ea396126f1e2.png

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文件

https://i-blog.csdnimg.cn/blog_migrate/bfd3a3ce5954ca79f6f55de033aaa18b.png

excel对应的实体类

https://i-blog.csdnimg.cn/blog_migrate/b528f52db6776e0100280fd88d89c821.png

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、编写控制层代码


https://i-blog.csdnimg.cn/blog_migrate/a494206d58090716f93260eb6bd077d1.png

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、接口代码

https://i-blog.csdnimg.cn/blog_migrate/407dadd90ca5f4a8704040d80ff91c2b.png

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

https://i-blog.csdnimg.cn/blog_migrate/7f88789822a6f2d6d6f94ad9f8871283.png

总结一下

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

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

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

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

https://i-blog.csdnimg.cn/blog_migrate/60cb7c1b74474d7e5a5546cc285d7586.png

https://i-blog.csdnimg.cn/blog_migrate/8bb05c431555e98a9a843fe5fa668b9d.png

前端面试题汇总

https://i-blog.csdnimg.cn/blog_migrate/0e3e725c2b52c0d80cc380a18efe5fd9.png

JavaScript

https://i-blog.csdnimg.cn/blog_migrate/9320ddadc20aa9901f6059017c06bce9.png

性能

https://i-blog.csdnimg.cn/blog_migrate/80f436616b3456a1e3fabb96c355d408.png

linux

https://i-blog.csdnimg.cn/blog_migrate/9ddd13c78eef6f7bdd7d52f641a2ff76.png

前端资料汇总

https://i-blog.csdnimg.cn/blog_migrate/76efd569a51c5aef0b8848e79c9e7dd7.png

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