您好,登錄后才能下訂單哦!
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的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。