已有的springcloud+mybatis项目升级为mybatis-plus的方法

已有的springcloud+mybatis项目升级为mybatis-plus

项目模块目录

将mybatis依赖替换为mybatis-plus

修改配置文件

实体类如果与数据库不同名需要加上@TableName

@Data
@TableName("project_base")
public class ProjectBase {
 @TableId(value = "id", type = IdType.UUID)//id看具体项目要求如果是后台生成则不需要type属性,如果不是后台生成不管是自增还是唯一键还是填入都需type属性
  private String id;
	 private String prjid;

  private String ccode;

  private String cname;

  private String orgbuild;

  @TableField(fill = FieldFill.INSERT_UPDATE)、//自动填充时间需要一个继承MetaObjectHandler的类,下一个
  private Date createtime;
  @TableField(fill = FieldFill.UPDATE)
  private Date updatetime;
  @TableLogic//需要配置文件开启逻辑删除
  private Boolean del;

  @Version//版本字段数据库不是一定为version只需要在版本字段上加上注解就可以
  private Integer version;
package com.itpm.server.Handler;

import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import lombok.extern.slf4j.Slf4j;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;

import java.util.Date;

@Component
@Slf4j
public class MyMateHandler implements MetaObjectHandler {
  @Override
  public void insertFill(MetaObject metaObject) {
    this.setFieldValByName("createtime",new Date(),metaObject);
    this.setFieldValByName("updatetime",new Date(),metaObject);
  }

  @Override
  public void updateFill(MetaObject metaObject) {
    this.setFieldValByName("updatatime",new Date(),metaObject);
  }
}

继承BaseMapper

原有接口可以不变,也可以把同名的接口名改了,比如plus的insert和原有的insert同名

package com.itpm.server.mapper.project;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.itpm.server.domain.project.ProjectBase;
import com.itpm.server.domain.project.ProjectBaseExample;
import com.itpm.server.dto.project.ProjectBaseDto;
import org.apache.ibatis.annotations.Param;

import java.util.List;
import java.util.Map;

public interface ProjectBaseMapper extends BaseMapper<ProjectBase> {
  long countByExample(ProjectBaseExample example);

  int deleteByExample(ProjectBaseExample example);

  int deleteByPrimaryKey(String id);

  int insertlist(List<ProjectBase> list);

  int insert(ProjectBase record);

  int insertSelective(ProjectBase record);

  List<ProjectBaseDto> selectByExample(ProjectBaseExample example);

  ProjectBaseDto selectByPrimaryKey(String id);

  int updateByExampleSelective(@Param("record") ProjectBase record, @Param("example") ProjectBaseExample example);

  int updateByExample(@Param("record") ProjectBase record, @Param("example") ProjectBaseExample example);

  int updateByPrimaryKeySelective(ProjectBase record);

  int updateByPrimaryKey(ProjectBase record);

  ProjectBaseDto selectByPrjid(Map map);

  List<ProjectBaseDto> selectByprojectoverview(String prjid);

  List<ProjectBaseDto> selectProjectByExample(ProjectBaseExample example);

  List<ProjectBaseDto> selectProjectByparams(@Param("record") Map record);

}

Service层

service层可以继承IService。如果想都自己写不继承也可以

代码生成器

与之前的mybatis代码生成器不冲突,可以选择也可以一起用
我的要生成在公共模块server下

 <dependency>
        <groupId>com.baomidou</groupId>
        <artifactId>mybatis-plus-generator</artifactId>
        <version>3.0.6</version>
      </dependency>
 <dependency>
        <groupId>org.freemarker</groupId>
        <artifactId>freemarker</artifactId>
        <version>2.3.29</version>
      </dependency>

```默认的是freemaker模板可以用其他的,需要导入其他依赖并且代码设置如下,当然可以做成一个util方便,mapper.xml默认生成在mapper层下xml包下,如果需要在resouce下生成需要自定义输出位置

package com.itpm.generator.server;

import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.annotation.FieldFill;
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.TableFill;
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.io.File;
import java.util.ArrayList;
import java.util.List;

public class ProjectKing {
  public static void main(String[] args) {
    //需要构建一个代码自动生成器对象
    AutoGenerator autoGenerator = new AutoGenerator();
    //配置策略
    //1.全局配置
    GlobalConfig globalConfig = new GlobalConfig();
    File file = new File("server");
    String path = file.getAbsolutePath();
//    String property = System.getProperty("user.dir");
    globalConfig.setOutputDir(path + "/src/main/java");
    globalConfig.setAuthor("蒋磊");
    globalConfig.setOpen(false);
    globalConfig.setBaseResultMap(true);
    globalConfig.setBaseColumnList(true);
    globalConfig.setFileOverride(false);//是否覆盖
    globalConfig.setServiceName("%sService");//去service的i前缀
    globalConfig.setIdType(IdType.UUID);
    globalConfig.setDateType(DateType.ONLY_DATE);
    globalConfig.setSwagger2(true);
    autoGenerator.setGlobalConfig(globalConfig);
    //2设置数据源
    DataSourceConfig dataSourceConfig = new DataSourceConfig();
    dataSourceConfig.setUrl("jdbc:mysql://itpm.itycu.com/itpm?characterEncoding=UTF8&autoReconnect=true&&allowMultiQueries=true");
    dataSourceConfig.setDriverName("com.mysql.jdbc.Driver");
    dataSourceConfig.setUsername("root");
    dataSourceConfig.setPassword("Itycu.8594");
    dataSourceConfig.setDbType(DbType.MYSQL);
    autoGenerator.setDataSource(dataSourceConfig);
    //包的配置
    PackageConfig packageConfig = new PackageConfig();
    packageConfig.setModuleName("server");
    String a="project";
    packageConfig.setParent("com.itpm");
//    packageConfig.setEntity("entity");
//    packageConfig.setMapper("mapper");
//    packageConfig.setService("service");
//    packageConfig.setController("controller");
    packageConfig.setEntity("domain."+a);
    packageConfig.setMapper("mapper."+a);
    packageConfig.setService("service."+a);
    packageConfig.setServiceImpl("service."+a+".impl");
    packageConfig.setController("controller."+a);
   // 自定义配置
    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 path + "/src/main/resources/mapper/" + a
            + "/" + 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);
    autoGenerator.setCfg(cfg);
    templateConfig.setXml(null);
    autoGenerator.setTemplate(templateConfig);

    autoGenerator.setPackageInfo(packageConfig);
    //4策略配置
    StrategyConfig strategyConfig = new StrategyConfig();
    strategyConfig.setNaming(NamingStrategy.underline_to_camel);
    strategyConfig.setColumnNaming(NamingStrategy.underline_to_camel);
    ArrayList<String> objects = new ArrayList<>();
//    objects.add("etest");
    objects.add("rtest");
    strategyConfig.setInclude(objects.toArray(new String[objects.size()]));//设置要映射的表名

//    strategyConfig.setSuperEntityClass("");
    strategyConfig.setEntityLombokModel(true);//自动lombok
    strategyConfig.setRestControllerStyle(true);
    strategyConfig.setLogicDeleteFieldName("deletedd");//逻辑删除字段
    //自动填充配置
    TableFill createtime = new TableFill("create_time", FieldFill.INSERT);
    TableFill updatetime = new TableFill("update_time", FieldFill.UPDATE);
    ArrayList<TableFill> tableFills = new ArrayList<>();
    strategyConfig.setTableFillList(tableFills);
    //乐观锁
    strategyConfig.setVersionFieldName("berv");
    strategyConfig.setRestControllerStyle(true);
    strategyConfig.setControllerMappingHyphenStyle(true);//localhost:8080/hello_id_2
    autoGenerator.setStrategy(strategyConfig);
    autoGenerator.setTemplateEngine(new FreemarkerTemplateEngine());
    //执行
    autoGenerator.execute();
 }
}

到此这篇关于已有的springcloud+mybatis项目升级为mybatis-plus的方法的文章就介绍到这了,更多相关springcloud+mybatis项目升级为mybatis-plus内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 从零开始搭建springboot+springcloud+mybatis本地项目全过程(图解)

    记录一下从零开始搭建一个springboot+springcloud+mybatis本地项目的demo的过程.纯代码小白一枚,若有不足或错误之处,欢迎广大朋友指出! 开发环境准备: IDE:IntelliJ Idea 2019.3 数据库:mysql 8.0.2.2 SpringBoot版本:2.2.0.RELEASE SpringCloud版本:Hoxton.RELEASE 一.创建一个新的Idea项目 打开Idea,单击New->File->Project,选择Maven,直接下一步 输入

  • Springcloud+Mybatis使用多数据源的四种方式(小结)

    前段时间在做会员中心和中间件系统开发时,多次碰到多数据源配置问题,主要用到分包方式.参数化切换.注解+AOP.动态添加 这四种方式.这里做一下总结,分享下使用心得以及踩过的坑. 分包方式 数据源配置文件 在yml中,配置两个数据源,id分别为master和s1. spring: datasource: master: jdbcUrl: jdbc:mysql://192.168.xxx.xxx:xxxx/db1?......... username: xxx password: xxx drive

  • SpringCloud+MyBatis分页处理(前后端分离)

    分页处理,这是做JavaWeb项目中常见的场景. 背景: 1.系统架构:SpringCloud分布式 2.持久层:MyBatis 3.前端:前后分离vue.js/bootstrap等. 后台提供restful api 接口,前端访问后端接口展示数据. 2种方式提供分页处理方案: 一.直接MyBatis数据库进行分页 controller接口 @ApiImplicitParams({ @ApiImplicitParam(name = "categoryId", value = "

  • 已有的springcloud+mybatis项目升级为mybatis-plus的方法

    已有的springcloud+mybatis项目升级为mybatis-plus 项目模块目录 将mybatis依赖替换为mybatis-plus 修改配置文件 实体类如果与数据库不同名需要加上@TableName @Data @TableName("project_base") public class ProjectBase { @TableId(value = "id", type = IdType.UUID)//id看具体项目要求如果是后台生成则不需要type

  • Asp.NetCore3.1开源项目升级为.Net6.0的方法实现

    目录 概述 需求 目前解决方案 总结 概述 自从.Net6.0出来后,一直想之前开发的项目升级.Net6.0,有时想想毕竟中间还跨了个5.0版本,升级起来不知道坑大不大,最近抽时间对升级的方案做了些研究,然后将代码升级为.Net6.0.本质上来说我个人不太喜欢.Net6.0去掉main方法和startup,微软这么干让初学者学习的门槛其实是更高了,但阻挡不住我喜欢.Net6.0项目的发布包体积确实小等!来,开干吧! 首先我们看下asp.netcore3.1的program代码: public c

  • IDEA创建springboot + mybatis项目全过程(步骤详解)

    鉴于隔很久再在IDEA新建springboot项目时,会出现对步骤不确定的情况,因此,写下这篇博客记录创建一个可运行的springboot+mybatis项目的全过程. 步骤如下: 1.打开IDEA 2.File ==> new ==> project ,如图: 3.选择spring Initializr ==> 右边的Project SDK我选的是我已经安装的1.8版本,其他默认 ==> 点击next 4.填写Group (自己随意就行,我的是cn + 个人英文名 + study

  • mybatis 项目配置文件实例详解

    mybatis项目配置 首先这事一个简单的mybatis项目配置文件: <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"> <configur

  • Spring + Mybatis 项目实现动态切换数据源实例详解

    项目背景:项目开发中数据库使用了读写分离,所有查询语句走从库,除此之外走主库. 最简单的办法其实就是建两个包,把之前数据源那一套配置copy一份,指向另外的包,但是这样扩展很有限,所有采用下面的办法. 参考了两篇文章如下: http://www.jb51.net/article/111840.htm http://www.jb51.net/article/111842.htm 这两篇文章都对原理进行了分析,下面只写自己的实现过程其他不再叙述. 实现思路是: 第一步,实现动态切换数据源:配置两个D

  • 微信开发准备第二步 springmvc mybatis项目结构搭建

    前面一篇有说道如何在MyEclipse中搭建maven项目,这里将继续介绍如何在搭建好的基础maven项目中引入我们常用的javaweb框架--SpringMVC! ①在建立好的maven项目中的pom.xml文件引入依赖,代码如下: <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schem

  • springboot+springmvc+mybatis项目整合

    介绍: 上篇给大家介绍了ssm多模块项目的搭建,在搭建过程中spring整合springmvc和mybatis时会有很多的东西需要我们进行配置,这样不仅浪费了时间,也比较容易出错,由于这样问题的产生,Pivotal团队提供了一款全新的框架,该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置.通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者. 特点: 1. 创建独立的Spring应用

  • Java Fluent Mybatis 项目工程化与常规操作详解流程篇 下

    目录 前言 查询 查询写法1 查询写法2 代码说明 新问题 删 总结 前言 接着上一篇:Java Fluent Mybatis 项目工程化与常规操作详解流程篇 上 仓库地址:GitHub仓库 查询 定义查询请求体 package com.hy.fmp.dto.req; import lombok.AllArgsConstructor; import lombok.Builder; import lombok.Data; import lombok.NoArgsConstructor; /** @

  • Java Fluent Mybatis 项目工程化与常规操作详解流程篇 上

    目录 前言 Maven依赖 配置文件调整 Knife4j配置 添加必要实体 增/改 总结 前言 接着上一篇,上篇已经测试通过,成功添加了数据.那么这篇主要是继续上一个项目,将项目进行工程化包装,增加一些必要配置,并且生成增删改查接口. GitHub代码仓库:GitHub仓库 Maven依赖 增加了druid数据库连接池,所以之前的配置文件也需要调整,下面会发出来. <dependency> <groupId>cn.hutool</groupId> <artifac

  • springboot-curd基于mybatis项目搭建

    项目结构: pom.xml文件:   <parent>         <groupId>org.springframework.boot</groupId>         <artifactId>spring-boot-starter-parent</artifactId>         <version>2.2.2.RELEASE</version>         <relativePath/>  

随机推荐