zoukankan      html  css  js  c++  java
  • Mybatis Plus 2 升到 Mybatis Plus 3 时,oracle 自增序列的相关问题

    一、Mybatis Plus 2,oracle 自增序列配置

    1. config.yml 配置文件

    #mybaits-plus配置,修改主键类型,mapper.xml、type 别名等
    mybatis-plus:
      mapper-locations: classpath:/mapper/*Mapper.xml
      global-config:
        #主键类型  0:"数据库ID自增", 1:"用户输入ID",2:"全局唯一ID (数字类型唯一ID)", 3:"全局唯一ID UUID";
        id-type: 1
        # Sequence序列接口实现类配置
        key-generator: com.baomidou.mybatisplus.incrementer.OracleKeyGenerator
    

    2. MybatisPlusConfigurer.java 配置

    @Configuration
    @MapperScan("user.mapper")
    public class MybatisPlusConfigurer {
    
    }
    

    3. 实体配置

    @TableName("T_USER")
    @KeySequence(value = "SEQ_USER", clazz = Integer.class)
    public class User extends Model<User> {
    
        private static final long serialVersionUID = 1L;
    
        /**
         * 用户ID
         */
        @TableId(value = "USER_ID", type = IdType.INPUT)
        private Integer userId;
    }
    
    

    二、Mybatis Plus 3,oracle 自增序列配置

    1. config.yml 配置文件

    #mybaits-plus配置,修改主键类型,mapper.xml、type 别名等
    mybatis-plus:
      mapper-locations: classpath:/mapper/*Mapper.xml
      global-config:
        #主键类型  0:"数据库ID自增", 1:"用户输入ID",2:"全局唯一ID (数字类型唯一ID)", 3:"全局唯一ID UUID";
        id-type: 1
        # Sequence序列接口实现类配置
        key-generator: com.baomidou.mybatisplus.extension.incrementer.OracleKeyGenerator
    

    Mybatis Plus 3 已废除此配置,但是配置该属性也不会出错。建议不配置。源代码说明如下:
    Mybatis Plus 3 的 key-generator 属性说明

    2. MybatisPlusConfigurer.java 配置

    @Configuration
    @MapperScan("user.mapper")
    public class MybatisPlusConfigurer {
    
    	/**
    	 * Sequence主键自增
    	 *
    	 * @return 返回oracle自增类
    	 * @author zhenggc
    	 * @date 2019/1/2
    	 */
    	@Bean
    	public OracleKeyGenerator oracleKeyGenerator(){
    		return new OracleKeyGenerator();
    	}
    }
    

    3. 实体配置

    @TableName("T_USER")
    @KeySequence(value = "SEQ_USER", clazz = Integer.class)
    public class User extends Model<User> {
    
        private static final long serialVersionUID = 1L;
    
        /**
         * 用户ID
         */
        @TableId(value = "USER_ID", type = IdType.INPUT)
        private Integer userId;
    }
    
    

    三、Mybatis Plus 2 升到 Mybatis Plus 3,有两个配置文件存在差异

    1. config.yml 配置文件的差异,OracleKeyGenerator 的包路径变了

    Mybatis Plus 2 :

    key-generator: com.baomidou.mybatisplus.incrementer.OracleKeyGenerator
    

    Mybatis Plus 3 :

    key-generator: com.baomidou.mybatisplus.extension.incrementer.OracleKeyGenerator
    

    并且 Mybatis Plus 3 无需配置该属性。

    2. MybatisPlusConfigurer.java 配置的差异

    Mybatis Plus 2 不需要配置 OracleKeyGenerator 的 bean ,而 Mybatis Plus 3 需要配置 OracleKeyGenerator。

  • 相关阅读:
    修改采购订单项目的内容显示、更改
    100小时学会sap傻瓜式入门版财务篇之co篇
    100小时学会sap傻瓜式入门版销售与分销sd篇
    100小时学会sap傻瓜式入门版生产计划pp篇
    ABAP SYNTAX COLLECTION II
    100小时学会sap傻瓜式入门版物料管理mm篇
    【转】systemconfigkickstart Package selection is disabled due to problems
    【转】如何在同一台机器上配置多个jboss应用服务器实例(以jboss4.0.5为标准)
    Windows7 install jeklly
    【转】VBoxManage命令详解
  • 原文地址:https://www.cnblogs.com/zhenggc/p/13655501.html
Copyright © 2011-2022 走看看