浅谈MyBatis-Plus学习之Oracle的主键Sequence设置的方法

所属分类: 软件编程 / java 阅读数: 99
收藏 0 赞 0 分享

一、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

更多精彩内容其他人还在看

Spring boot将配置属性注入到bean类中

本篇文章主要介绍了Spring boot将配置属性注入到bean类中,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

Java正则判断日期格式是否正确的方法示例

这篇文章主要介绍了Java正则判断日期格式是否正确的方法,结合实例形式分析了Java针对日期字符串正则判断的相关操作技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

java Future 接口使用方法详解

这篇文章主要介绍了java Future 接口使用方法详解,Future接口是Java线程Future模式的实现,可以来进行异步计算的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

Java 读取外部资源的方法详解及实例代码

这篇文章主要介绍了Java 读取外部资源的方法详解及实例代码的相关资料,经常有读取外部资源的要求,如配置文件等等需要读取,需要的朋友可以参考下
收藏 0 赞 0 分享

Java正则表达式之split()方法实例详解

这篇文章主要介绍了Java正则表达式之split()方法,结合实例形式较为详细的分析了split方法的功能、使用方法及相关注意事项,需要的朋友可以参考下
收藏 0 赞 0 分享

Java 存储模型和共享对象详解

这篇文章主要介绍了Java 存储模型和共享对象详解的相关资料,对Java存储模型,可见性和安全发布的问题是起源于Java的存储结构及共享对象安全,需要的朋友可以参考下
收藏 0 赞 0 分享

Java使用正则表达式实现找出数字功能示例

这篇文章主要介绍了Java使用正则表达式实现找出数字功能,结合实例形式分析了Java针对数字的匹配查找及非数字替换操作相关实现技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

Spring核心IoC和AOP的理解

本文主要介绍了Spring核心IoC和AOP的相关知识。具有很好的参考价值,下面跟着小编一起来看下吧
收藏 0 赞 0 分享

详解Spring AOP 拦截器的基本实现

本篇文章主要介绍了详解Spring AOP 拦截器的基本实现,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

Mybatis 中的一对一,一对多,多对多的配置原则示例代码

这篇文章主要介绍了 Mybatis 中的一对一,一对多,多对多的配置原则示例代码,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多