一、Oracle的主键Sequence设置简介
在Oracle数据库中不支持主键自增策略,它是通过Sequence序列来进行完成的,因此需要在MP中进行相关配置
二、相关配置如下
2.1、pom.xml 添加相关依赖
注意:由于oracle的授权问题,没办法从maven仓库中下载,因此可以手动从oracle官网中下载,并本地打包到仓库中
<dependency> <groupId>com.oraclegroupId> <artifactId>ojdbc14artifactId> <version>10.2.0.4.0version> 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设置
<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配置
<bean id="globalConfiguration" class="com.baomidou.mybatisplus.entity.GlobalConfiguration"> <property name="dbColumnUnderline" value="true">property> <property name="idType" value="0">property> <property name="tablePrefix" value="tbl_">property> <property name="keyGenerator" ref="oracleKeyGenerator">property> bean> <bean id="oracleKeyGenerator" class="com.baomidou.mybatisplus.incrementer.OracleKeyGenerator">bean>
本质:
其实在Oracle数据库中进行新增数据首先在数据库中先执行
select seq_user.nextval from dual;这样获取下一个主键的序列,然后再执行插入操作
另外:
实际开发中可能会有很多个实体类,所以在每个实体类上都加上@KeySequence,显得很繁琐
假如需要多个实体公用同一个序列
可以将@keySequence 定义在父类中, 可实现多个子类对应的多个表公用一个 Sequence