mybatis-plus代码生成器以及mybatis版本代码生成器:

mybatis-plus:

------------------------------------------------------------------

        
            com.baomidou
            mybatis-plus-boot-starter
            3.4.0
        
-------------------------
# 数据源的配置
spring.datasource.druid.password=root
spring.datasource.druid.username=root
spring.datasource.druid.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.druid.url=jdbc:mysql:///mybatis-plus?serverTimezone=UTC

这样防止编码乱以及时间错八个小时
spring.datasource.druid.url=jdbc:mysql:///ssm_crud?serverTimezone=Asia/Shanghai&characterEncoding=utf8
------------------------

import com.baomidou.mybatisplus.core.exceptions.MybatisPlusException;
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 org.apache.commons.lang3.StringUtils;

import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

// 演示例子,执行 main 方法控制台输入模块表名回车自动生成对应项目目录中
public class CodeGenerator {

    /**
     * 

* 读取控制台内容 *

*/ public static String scanner(String tip) { Scanner scanner = new Scanner(System.in); StringBuilder help = new StringBuilder(); help.append("请输入" + tip + ":"); System.out.println(help.toString()); if (scanner.hasNext()) { String ipt = scanner.next(); if (StringUtils.isNotBlank(ipt)) { return ipt; } } throw new MybatisPlusException("请输入正确的" + tip + "!"); } public static void main(String[] args) { // 代码生成器 AutoGenerator mpg = new AutoGenerator(); // 全局配置 GlobalConfig gc = new GlobalConfig(); // 获取工程的根目录 String projectPath = System.getProperty("user.dir"); gc.setOutputDir(projectPath + "/src/main/java");// gc.setAuthor("xiaozhang"); gc.setOpen(false);//是否生成代码后打开本地目录 gc.setSwagger2(true); //是否生存实体属性 Swagger2 注解 gc.setServiceName("%sService"); //service命名 gc.setMapperName("%sMapper"); //Dao命名 // mpg.setGlobalConfig(gc);//是否设置全局配置 // 数据源配置 DataSourceConfig dsc = new DataSourceConfig(); dsc.setUrl("jdbc:mysql://localhost:3306/ai?serverTimezone=Asia/Shanghai&useUnicode=true&useSSL=false&characterEncoding=utf8"); // dsc.setSchemaName("public"); dsc.setDriverName("com.mysql.cj.jdbc.Driver"); dsc.setUsername("root"); dsc.setPassword("root"); mpg.setDataSource(dsc); // 包配置 PackageConfig pc = new PackageConfig(); pc.setModuleName("car");//模块名 pc.setParent("com.aaa");//设置父包 com.zz.aaa.controller mapper service entity // 设置dao pc.setMapper("mapper"); mpg.setPackageInfo(pc); // 自定义配置 InjectionConfig cfg = new InjectionConfig() { @Override public void initMap() { // to do nothing } }; // 如果模板引擎是 velocity String templatePath = "/templates/mapper.xml.vm"; // 自定义输出配置 List focList = new ArrayList<>(); // 预计目录 mapper/UserMapper.xml focList.add(new FileOutConfig(templatePath) { @Override public String outputFile(TableInfo tableInfo) { // 自定义输出文件名 , 如果你 Entity 设置了前后缀、此处注意 xml 的名称会跟着发生变化!! return projectPath + "/src/main/resources/mapper/" + tableInfo.getEntityName() + "Mapper" + StringPool.DOT_XML; } }); // 配置模板 TemplateConfig templateConfig = new TemplateConfig(); //关闭系统模板引擎 templateConfig.setXml(null); //放入空的模板引擎替换掉默认的模板引擎 mpg.setTemplate(templateConfig); cfg.setFileOutConfigList(focList); mpg.setCfg(cfg); // 策略配置 StrategyConfig strategy = new StrategyConfig(); strategy.setNaming(NamingStrategy.underline_to_camel);//是否采用驼峰命名 strategy.setColumnNaming(NamingStrategy.underline_to_camel);//列是否要驼峰命名 strategy.setEntityLombokModel(true);// 是否要lombok // 如果数据库有前缀,生成文件时是否要前缀acl_ /*strategy.setTablePrefix("bus_"); strategy.setTablePrefix("sys_");*/ strategy.setRestControllerStyle(true);//controller是否使用restful风格 mpg.setStrategy(strategy); mpg.execute(); } } -----------------------------------------------------------------------------------

-----------------------------------------------------------------------------------

创建 MBG 配置⽂件 generatorConfig.xml

1、jdbcConnection 配置数据库连接信息。

2、javaModelGenerator 配置 JavaBean 的⽣成策略。

3、sqlMapGenerator 配置 SQL 映射⽂件⽣成策略。

4、javaClientGenerator 配置 Mapper 接⼝的⽣成策略。

5、table 配置⽬标数据表(tableName:表名,domainObjectName:JavaBean 类名)

(1)引入依赖


            org.mybatis.generator
            mybatis-generator-core
            1.4.0
        

(2) 配置内容---放到工程下




    
    
​
    
        
            
        
        
        
        
​
        
            
        
​
        
        
            
            
        
​
        
        
            
        
​
        
        
            
        
​
        
        
            
            
            
            
            
        
​                                                                            
​    

、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、

public class TestGenerator {
    public static void main(String[] args) throws Exception {
        List warnings = new ArrayList();
        boolean overwrite = true;
        File configFile = new File("generator.xml");
        ConfigurationParser cp = new ConfigurationParser(warnings);
        Configuration config = cp.parseConfiguration(configFile);
        DefaultShellCallback callback = new DefaultShellCallback(overwrite);
        MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings);
        myBatisGenerator.generate(null);
    }
}


 

你可能感兴趣的:(mybatis-数据库,java,开发语言,后端,mybatis,mybatis-plus)