1. 程式人生 > 程式設計 >淺談MyBatis-Plus學習之Oracle的主鍵Sequence設定的方法

淺談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

到此這篇關於淺談MyBatis-Plus學習之Oracle的主鍵Sequence設定的方法的文章就介紹到這了,更多相關Mybatis-Plus Oracle 主鍵Sequence內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!