使用mybaitsplus的代码生成器后CRUD出现错误的问题:
- java.lang.IllegalStateException: Unable to find a @SpringBootConfiguration, you need to use @ContextConfiguration or @SpringBootTest(classes=…) with your test
- NullPoint的问题
- 提示错误信息 Autowired require =true
错误原因:
生成代码后自动导包错误,需要查看生成包中的import,将MVC中的M层统一替换 Model、BaseMapper、IService、ServiceImpl的import为generate.jar下的类,我的idea由于自动导入suppot.jar中的类因此使用报错
解决方案:
需要改的import
实体类(用于AR)
import com.baomidou.mybatisplus.extension.activerecord.Model;
mapper
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
接口service
import com.baomidou.mybatisplus.extension.service.IService;
接口实现类
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
问题探究:
我对比了两个import
为什么需要依赖这个support.jar包
- 代码生成
- 实体类@TableId、@TableField等注解
为什么需要依赖generate.jar包
- 实体类继承 Model 用于AR
- mapper层继承的 BaseMapper
- service接口层继承 IService
- service实现类继承 ServiceImpl
这就带来一个问题,如果数据库中表很多,那么带来的改动就会变的很多,手动导入则会非常费劲
我能想到的一个笨办法就是,在代码生成完后,先暂时取消support.jar的依赖,然后点击每个生成的类中让idea自动导包为generate.jar包的类。之后在将support.jar依赖加回来,来支持实体类中的注解
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generate</artifactId>
<version>2.2.0</version>
<!-- 取消依赖 ,加回来的话注释掉就可以-->
<exclusions>
<exclusion>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-support</artifactId>
</exclusion>
</exclusions>
</dependency>
我的springboot依赖:
<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.1.1</version>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generate</artifactId>
<version>2.2.0</version>
<!--<exclusions>-->
<!--<exclusion>-->
<!--<groupId>com.baomidou</groupId>-->
<!--<artifactId>mybatis-plus-support</artifactId>-->
<!--</exclusion>-->
<!--</exclusions>-->
</dependency>
<!--自动生成模板-->
<dependency>
<groupId>org.freemarker</groupId>
<artifactId>freemarker</artifactId>
<version>2.3.29</version>
</dependency>
<!--连接池-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.12</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
<exclusions>
<exclusion>
<groupId>org.junit.vintage</groupId>
<artifactId>junit-vintage-engine</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
<build>
<!-- 添加资源 -->
<resources>
<resource>
<directory>src/main/resources</directory>
<!-- src/main/resources下的指定资源放行 -->
<includes>
<include>**/*.properties</include>
<include>**/*.yml</include>
<include>**/**/*.xml</include>
</includes>
<filtering>false</filtering>
</resource>
</resources>
</build>
附加我的代码生成
package com;
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.NamingStrategy;
import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;
public class CodeGenerator {
public static void main(String[] args) {
//表名,多个表就加多个表的名字
String[] tableName = {"user","tb_user"};
//加入是 com.study.fastdfsweb
String packageName = "com.study";
String artifactId = "fastdfsweb";
//如果是此工程下的一个module,则这个module的名字,生成代码写入这个module中
String moduleName="";
//以下是mysql配置
String dataBaseUrl = "jdbc:mysql://localhost:3306/mybatisplus?useUnicode=true&characterEncoding=UTF-8&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC";
String driverName = "com.mysql.cj.jdbc.Driver";
String username = "root";
String password = "123";
// 代码生成器
AutoGenerator mpg = new AutoGenerator();
// 全局配置
GlobalConfig gc = new GlobalConfig();
String projectPath = System.getProperty("user.dir")+moduleName;
gc.setOutputDir(projectPath + "/src/main/java");
gc.setAuthor("");
gc.setOpen(false);
// gc.setSwagger2(true); 实体属性 Swagger2 注解
mpg.setGlobalConfig(gc);
// 数据源配置
DataSourceConfig dsc = new DataSourceConfig();
dsc.setUrl(dataBaseUrl);
// dsc.setSchemaName("public");
dsc.setDriverName(driverName);
dsc.setUsername(username);
dsc.setPassword(password);
mpg.setDataSource(dsc);
// 包配置
PackageConfig pc = new PackageConfig();
pc.setModuleName(artifactId);
pc.setParent(packageName);
mpg.setPackageInfo(pc);
// 自定义配置
InjectionConfig cfg = new InjectionConfig() {
@Override
public void initMap() {
// to do nothing
}
};
// 如果模板引擎是 freemarker
String templatePath = "/templates/mapper.xml.ftl";
// 如果模板引擎是 velocity
//String templatePath = "/templates/mapper.xml.vm";
// 自定义输出配置
List<FileOutConfig> focList = new ArrayList<>();
// 自定义配置会被优先输出
focList.add(new FileOutConfig(templatePath) {
@Override
public String outputFile(TableInfo tableInfo) {
// 自定义输出文件名 , 如果你 Entity 设置了前后缀、此处注意 xml 的名称会跟着发生变化!!
return projectPath + "/src/main/resources/mapper/" + pc.getModuleName()
+ "/" + tableInfo.getEntityName() + "Mapper" + StringPool.DOT_XML;
}
});
cfg.setFileOutConfigList(focList);
mpg.setCfg(cfg);
// 配置模板
TemplateConfig templateConfig = new TemplateConfig();
templateConfig.setXml(null);
mpg.setTemplate(templateConfig);
// 策略配置
StrategyConfig strategy = new StrategyConfig();
strategy.setNaming(NamingStrategy.underline_to_camel);
strategy.setColumnNaming(NamingStrategy.underline_to_camel);
//strategy.setSuperEntityClass("你自己的父类实体,没有就不用设置!");
strategy.setEntityLombokModel(true);
strategy.setRestControllerStyle(true);
// 公共父类
//strategy.setSuperControllerClass("你自己的父类控制器,没有就不用设置!");
// 写于父类中的公共字段
//strategy.setSuperEntityColumns("id");
strategy.setInclude(tableName);
strategy.setControllerMappingHyphenStyle(true);
strategy.setTablePrefix(pc.getModuleName() + "_");
mpg.setStrategy(strategy);
mpg.setTemplateEngine(new FreemarkerTemplateEngine());
mpg.execute();
System.out.println("生成地址:"+projectPath);
}
}
也可以在控制台中复制生成地址寻找生成代码