首页 > 编程知识 正文

springboot 管理系统,Springboot框架

时间:2023-05-06 05:55:04 阅读:131060 作者:3840

SpringBoot集成MyBatis-PLUS部署相关性内部独特的代码生成类配置Yml文件测试完成

dependencygroupidcom.Bao midou/groupidartifactidmybatis-plus-boot-starter/artifactidversion3.3.2/版本/依赖于--Mybatis-plus自动生成代码依赖于--dependencygroupidcom.Bao midou/groupidartifactidmybatis-plus-generator/artifactidversion3--- freemarker---dependencygroupidorg.freemarker/groupidartifactidfreeemarker/artifactidversiors

因为作者一般使用表生成代码,所以引入了自动生成代码依赖

生成表时需要FreeMaker依赖关系

编写自己的代码生成类package com.jshx.utils

import com.Bao midou.mybatisplus.core.exceptions.mybatisplusexception;

import com.Bao midou.mybatisplus.core.toolkit.stringpool;

import com.Bao midou.mybatisplus.generator.auto generator;

import com.Bao midou.mybatisplus.generator.injection config;

import com.Bao midou.mybatisplus.generator.config.*;

import com.Bao midou.mybatisplus.generator.config.po.tableinfo;

import com.Bao midou.mybatisplus.generator.config.rules.naming strategy;

import com.Bao midou.mybatisplus.generator.engine.freemarkertemplateengine;

importorg.Apache.com mons.lang.string utils;

import java.util.ArrayList;

import java.util.List;

import java.util.Scanner;

公共类my generator {

读取/** * p *控制台内容*/p */publicstaticstringscanner (stringtip ) scanner=new scanner ) system.in,' UTF-8。 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 '!' ); } publicstaticvoidmain (字符串[ ] args )//代码生成器autogeneratormpg=newautogenerator ); //全局配置全局配置GC=new全局配置(; GC.set service name (“% s服务”); stringprojectpath=system.getproperty (user.dir ); GC.set output dir (项目路径

"/src/main/java");//相对路径 gc.setAuthor("GuiZicheng"); gc.setOpen(false); // gc.setSwagger2(true); 实体属性 Swagger2 注解 mpg.setGlobalConfig(gc); // 数据源配置 DataSourceConfig dsc = new DataSourceConfig(); dsc.setUrl("jdbc:mysql://localhost:3306/test?useUnicode=true&壮观的水壶=UTF-8&useSSL=false&connectTimeout=60000&socketTimeout=60000&autoReconnect=true&autoReconnectForPools=true&failOverReadOnly=false"); // dsc.setSchemaName("public"); dsc.setDriverName("com.mysql.jdbc.Driver"); dsc.setUsername("root"); dsc.setPassword("123456"); mpg.setDataSource(dsc); // 包配置 PackageConfig pc = new PackageConfig(); pc.setModuleName(scanner("模块名")); pc.setParent("com.jshx"); 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.setFileCreate(new IFileCreate() { @Override public boolean isCreate(ConfigBuilder configBuilder, FileType fileType, String filePath) { // 判断自定义文件夹是否需要创建 checkDir("调用默认方法创建的目录,自定义目录用"); if (fileType == FileType.MAPPER) { // 已经生成 mapper 文件判断存在,不想重新生成返回 false return !new File(filePath).exists(); } // 允许生成模板文件 return true; } }); */ cfg.setFileOutConfigList(focList); mpg.setCfg(cfg); // 配置模板 TemplateConfig templateConfig = new TemplateConfig(); // 配置自定义输出模板 //指定自定义模板路径,注意不要带上.ftl/.vm, 会根据使用的模板引擎自动识别 // templateConfig.setEntity("templates/entity2.java"); // templateConfig.setService(); // templateConfig.setController(); 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(scanner("表名,多个英文逗号分割").split(",")); strategy.setControllerMappingHyphenStyle(true); strategy.setTablePrefix("t_"); mpg.setStrategy(strategy); mpg.setTemplateEngine(new FreemarkerTemplateEngine()); mpg.execute();}

}
注意:这里面关键部分为 配置数据源 数据源账号密码 生成文件位置可以看文件中路径相关的代码 另外 MyBatis-PLUS 包含了mybatis即不需要引入MyBatis的相关依赖了

配置Yml文件

mybatis-plus:
mapper-locations: classpath:mapper/zSeatFull/.xml #mapper路径
type-aliases-package: com.jshx..entity #起别名的类路径 支持通配符 首字母小写
mybatis-plus:
configuration:
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
global-config:
db-config:
logic-delete-field: delflag
logic-delete-value: 1 # 逻辑已删除值(默认为 1)
logic-not-delete-value: 0 # 逻辑未删除值(默认为 0)

测试

保证数据库正确的情况下
可以创建一个表 然后启动生成类 根据提示在控制台输入对应信息进行测试

补充

MyBatis-PLUS生成的表对象 默认没有主键生成策略需要的话自己配置
例:@TableId(value = “id”, type = IdType.AUTO)加在主键属性上
如果想要统一配置 可以在YML文件中添加

在这里插入代码片 global-config: db-config: id-type: auto 具体可以百度一下这个策略的用法

如果想要自增策略 数据库表设计需要修改ID为自增

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。