后端环境搭建
1.设计数据库
a.表的命名最好是 "业务名称_表的作用" 如edu_teacher
b.表必备三字段 id, gtm_create, gtm_modified
c.如果表名称/表字段 由多个单词组成,要用下划线_来分割(为了在逆向工程的时候生成驼峰式)
2.搭建项目的方式
a.方式一 (全部模块用单独的springboot 项目)
springboot模块一
springboot模块二
b.方式二(springboot作为父工程,maven作为子工程)
springboot作为父工程
maven模块一
maven模块二
3.搭建父工程 online_edu_parent
a.修改打包方式为pom
b.拷贝项目所有相关依赖(依赖如下)
c.删除src目录
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.atguigu</groupId>
<artifactId>online_edu_parent</artifactId>
<version>0.0.1-SNAPSHOT</version>
<modules>
<module>online_edu_service</module>
<module>online_edu_common</module>
</modules>
<name>online_edu_parent</name>
<description>Demo project for Spring Boot</description>
<packaging>pom</packaging>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.6.RELEASE</version>
</parent>
<properties>
<java.version>1.8</java.version>
<guli.version>0.0.1-SNAPSHOT</guli.version>
<mybatis-plus.version>3.5.2</mybatis-plus.version>
<velocity.version>2.0</velocity.version>
<swagger.version>2.9.2</swagger.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<!--mybatis-plus 持久层-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>${mybatis-plus.version}</version>
</dependency>
<!-- velocity 模板引擎, Mybatis Plus 代码生成器需要 -->
<dependency>
<groupId>org.apache.velocity</groupId>
<artifactId>velocity-engine-core</artifactId>
<version>${velocity.version}</version>
</dependency>
<!--swagger-->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>${swagger.version}</version>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>${swagger.version}</version>
</dependency>
</dependencies>
</dependencyManagement>
</project>
4.搭建模块 online_edu_service
a.用于后面跟业务有关的子模块
b.拷贝依赖 (依赖如下)
c.创建主类和配置文件
d.dependencies和dependencyManagement的区别
(dependencies用来导入依赖,dependencyManagement只进行以来版本的管理,不会导入依赖)
5.利用逆向工程生成代码
依赖
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>online_edu_parent</artifactId>
<groupId>com.atguigu</groupId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>online_edu_service</artifactId>
<dependencies>
<!--lombok-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
<!--swagger-->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
</dependency>
<!--mybatis-plus-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
</dependency>
<!--mysql-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<!-- velocity 模板引擎, Mybatis Plus 代码生成器需要 -->
<dependency>
<groupId>org.apache.velocity</groupId>
<artifactId>velocity-engine-core</artifactId>
</dependency>
<!--开发者工具-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>
</dependencies>
</project>
MybatisPlus逆向工程
import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.core.toolkit.StringPool;
import com.baomidou.mybatisplus.generator.AutoGenerator;
import com.baomidou.mybatisplus.generator.InjectionConfig;
import com.baomidou.mybatisplus.generator.config.*;
import com.baomidou.mybatisplus.generator.config.po.TableInfo;
import com.baomidou.mybatisplus.generator.config.rules.DateType;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;
import java.util.ArrayList;
import java.util.List;
public class CodeGenerator {
public static void main(String[] args) {
// 1、创建代码生成器
AutoGenerator autoGenerator = new AutoGenerator();
// 2、全局配置
GlobalConfig globalConfig = new GlobalConfig();
//String projectPath = System.getProperty("user.dir");
//globalConfig.setOutputDir(projectPath + "/src/main/java");
globalConfig.setOutputDir("D:\\SenSen_ideal\\online_edu_parent\\online_edu_service\\src\\main\\java");
globalConfig.setAuthor("CaoSenSen");
//生成后是否打开资源管理器
globalConfig.setOpen(true);
//重新生成时文件是否覆盖
globalConfig.setFileOverride(false);
//去掉Service接口的首字母I
globalConfig.setServiceName("%sService");
//主键策略
globalConfig.setIdType(IdType.ID_WORKER_STR);
//定义生成的实体类中日期类型
globalConfig.setDateType(DateType.ONLY_DATE);
//开启Swagger2模式
globalConfig.setSwagger2(true);
autoGenerator.setGlobalConfig(globalConfig);
// 3、数据源配置
DataSourceConfig dataSourceConfig = new DataSourceConfig();
dataSourceConfig.setUrl("jdbc:mysql://localhost:3306/db_guli?serverTimezone=GMT%2B8");
dataSourceConfig.setDriverName("com.mysql.cj.jdbc.Driver");
dataSourceConfig.setUsername("root");
dataSourceConfig.setPassword("991225");
dataSourceConfig.setDbType(DbType.MYSQL);
autoGenerator.setDataSource(dataSourceConfig);
// 4、包配置
PackageConfig packageConfig = new PackageConfig();
packageConfig.setModuleName(""); //模块名
packageConfig.setParent("com.atguigu.edu");
packageConfig.setController("controller");
packageConfig.setEntity("entity");
packageConfig.setService("service");
packageConfig.setMapper("mapper");
autoGenerator.setPackageInfo(packageConfig);
// 5、策略配置
StrategyConfig strategy = new StrategyConfig();
strategy.setInclude("edu_teacher");
strategy.setNaming(NamingStrategy.underline_to_camel);//数据库表映射到实体的命名策略
strategy.setTablePrefix(packageConfig.getModuleName() + "_"); //生成实体时去掉表前缀
strategy.setColumnNaming(NamingStrategy.underline_to_camel);//数据库表字段映射到实体的命名策略
strategy.setEntityLombokModel(true); // lombok 模型 @Accessors(chain = true) setter链式操作
strategy.setRestControllerStyle(true); //restful api风格控制器
strategy.setControllerMappingHyphenStyle(true); //url中驼峰转连字符
autoGenerator.setStrategy(strategy);
// 6、执行
autoGenerator.execute();
}
}