zoukankan      html  css  js  c++  java
  • 浅谈MyBatis-Plus学习之Oracle的主键Sequence设置

    一、Oracle的主键Sequence设置简介

    在Oracle数据库中不支持主键自增策略,它是通过Sequence序列来进行完成的,因此需要在MP中进行相关配置

    二、相关配置如下

    2.1、pom.xml 添加相关依赖

    注意:由于oracle的授权问题,没办法从maven仓库中下载,因此可以手动从oracle官网中下载,并本地打包到仓库中

    <!-- Oracle驱动: 因为Oracle授权的问题,不能从Maven的仓库中下载到Oracle驱动 -->
            <dependency>
                <groupId>com.oracle</groupId>
                <artifactId>ojdbc14</artifactId>
                <version>10.2.0.4.0</version>
            </dependency>

    2.2、db.properties 添加相关的连接配置信息

    orcl.driver=oracle.jdbc.OracleDriver
    orcl.url=jdbc:oracle:thin:@localhost:1521:mp
    orcl.username=username
    orcl.password=1234

    2.3、applicationContext.xml 添加dataSource设置

    <!-- Oracle -->
        <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
            <property name="driverClass" value="${orcl.driver}"></property>
            <property name="jdbcUrl" value="${orcl.url}"></property>
            <property name="user" value="${orcl.username}"></property>
            <property name="password" value="${orcl.password}"></property>
        </bean>

    2.4、在Oracle中创建表数据及序列

    create table tbl_user(
     id number(10),
     name varchar2(32),
     delete_flag number(10)
    )
    -- 创建序列
    create sequence seq_user start with 1;

    2.5、实体相关配置

    注意两点:

    @KeySequence(value="seq_user",clazz=Integer.class) //value为数据库中生成的序列名,class指主键属性类型

     @TableId(type=IdType.INPUT)  //注意主键类型要指定为Input

    @KeySequence(value="seq_user",clazz=String.class) //value为数据库中生成的序列名,class指主键属性类型
    public class User {
         @TableId(type=IdType.INPUT)  //注意主键类型要指定为Input
         private String id;
         @TableField(fill=FieldFill.INSERT_UPDATE) //当插入和更新都会进行字段的填充
         private String name;
         @TableLogic  //标志是一个逻辑标识符号
         private Integer deleteFlag;
    }

    2.6、applicationContext.xml配置

     <!-- mybatis-plus全局配置策略 ,这样避免重复在每一个实体中使用注解进行配置-->
        <bean id="globalConfiguration" class="com.baomidou.mybatisplus.entity.GlobalConfiguration">
            <property name="dbColumnUnderline" value="true"></property>  <!-- 2.3版本后默认配置数据库下划线-->
            <!-- 指定数据库ID生成策略   0:数据库自增-->
            <property name="idType" value="0"></property>
            <!-- 指定数据库表前缀 -->
            <property name="tablePrefix" value="tbl_"></property>
            <!-- 注入Sequence -->
            <property name="keyGenerator" ref="oracleKeyGenerator"></property>
        </bean>
        
        <!-- 配置Oracle主键Sequence -->
        <bean id="oracleKeyGenerator" class="com.baomidou.mybatisplus.incrementer.OracleKeyGenerator"></bean>

    本质:

    其实在Oracle数据库中进行新增数据首先在数据库中先执行

    select seq_user.nextval from dual;这样获取下一个主键的序列,然后再执行插入操作

    另外:

    实际开发中可能会有很多个实体类,所以在每个实体类上都加上@KeySequence,显得很繁琐

    假如需要多个实体公用同一个序列

    可以将@keySequence 定义在父类中, 可实现多个子类对应的多个表公用一个 Sequence

     

  • 相关阅读:
    IDEA常用快捷键
    mybatis动态sql总结
    端口被占用的问题解决 Web server failed to start. Port ×× was already in use
    java常见的面试题(二)
    java常见的面试题(一)
    Zookeeper学习总结
    Oracle 创建表空间及用户授权、dmp数据导入、表空间、用户删除
    Navicat远程连接服务器mysql
    HashMap的实现原理?如何保证HashMap线程安全?
    ArrayList和LinkedList内部是怎么实现的?他们之间的区别和优缺点?
  • 原文地址:https://www.cnblogs.com/jayhou/p/9825874.html
Copyright © 2011-2022 走看看