淺談MyBatis-Plus學(xué)習(xí)之Oracle的主鍵Sequence設(shè)置的方法
一、Oracle的主鍵Sequence設(shè)置簡(jiǎn)介
在Oracle數(shù)據(jù)庫(kù)中不支持主鍵自增策略,它是通過(guò)Sequence序列來(lái)進(jìn)行完成的,因此需要在MP中進(jìn)行相關(guān)配置
二、相關(guān)配置如下
2.1、pom.xml 添加相關(guān)依賴(lài)
注意:由于oracle的授權(quán)問(wèn)題,沒(méi)辦法從maven倉(cāng)庫(kù)中下載,因此可以手動(dòng)從oracle官網(wǎng)中下載,并本地打包到倉(cāng)庫(kù)中
<!-- Oracle驅(qū)動(dòng): 因?yàn)镺racle授權(quán)的問(wèn)題,不能從Maven的倉(cāng)庫(kù)中下載到Oracle驅(qū)動(dòng) --> <dependency> <groupId>com.oracle</groupId> <artifactId>ojdbc14</artifactId> <version>10.2.0.4.0</version> </dependency>
2.2、db.properties 添加相關(guān)的連接配置信息
orcl.driver=oracle.jdbc.OracleDriver orcl.url=jdbc:oracle:thin:@localhost:1521:mp orcl.username=username orcl.password=1234
2.3、applicationContext.xml 添加dataSource設(shè)置
<!-- 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中創(chuàng)建表數(shù)據(jù)及序列
create table tbl_user( id number(10), name varchar2(32), delete_flag number(10) ) -- 創(chuàng)建序列 create sequence seq_user start with 1;
2.5、實(shí)體相關(guān)配置
注意兩點(diǎn):
@KeySequence(value="seq_user",clazz=Integer.class) //value為數(shù)據(jù)庫(kù)中生成的序列名,class指主鍵屬性類(lèi)型
@TableId(type=IdType.INPUT) //注意主鍵類(lèi)型要指定為Input
@KeySequence(value="seq_user",clazz=String.class) //value為數(shù)據(jù)庫(kù)中生成的序列名,class指主鍵屬性類(lèi)型 public class User { @TableId(type=IdType.INPUT) //注意主鍵類(lèi)型要指定為Input private String id; @TableField(fill=FieldFill.INSERT_UPDATE) //當(dāng)插入和更新都會(huì)進(jìn)行字段的填充 private String name; @TableLogic //標(biāo)志是一個(gè)邏輯標(biāo)識(shí)符號(hào) private Integer deleteFlag; }
2.6、applicationContext.xml配置
<!-- mybatis-plus全局配置策略 ,這樣避免重復(fù)在每一個(gè)實(shí)體中使用注解進(jìn)行配置--> <bean id="globalConfiguration" class="com.baomidou.mybatisplus.entity.GlobalConfiguration"> <property name="dbColumnUnderline" value="true"></property> <!-- 2.3版本后默認(rèn)配置數(shù)據(jù)庫(kù)下劃線(xiàn)--> <!-- 指定數(shù)據(jù)庫(kù)ID生成策略 0:數(shù)據(jù)庫(kù)自增--> <property name="idType" value="0"></property> <!-- 指定數(shù)據(jù)庫(kù)表前綴 --> <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>
本質(zhì):
其實(shí)在Oracle數(shù)據(jù)庫(kù)中進(jìn)行新增數(shù)據(jù)首先在數(shù)據(jù)庫(kù)中先執(zhí)行
select seq_user.nextval from dual;這樣獲取下一個(gè)主鍵的序列,然后再執(zhí)行插入操作
另外:
實(shí)際開(kāi)發(fā)中可能會(huì)有很多個(gè)實(shí)體類(lèi),所以在每個(gè)實(shí)體類(lèi)上都加上@KeySequence,顯得很繁瑣
假如需要多個(gè)實(shí)體公用同一個(gè)序列
可以將@keySequence 定義在父類(lèi)中, 可實(shí)現(xiàn)多個(gè)子類(lèi)對(duì)應(yīng)的多個(gè)表公用一個(gè) Sequence
到此這篇關(guān)于淺談MyBatis-Plus學(xué)習(xí)之Oracle的主鍵Sequence設(shè)置的方法的文章就介紹到這了,更多相關(guān)Mybatis-Plus Oracle 主鍵Sequence內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- mybatis-plus主鍵id生成、字段自動(dòng)填充的實(shí)現(xiàn)代碼
- mybatis-plus的selectById(或者selectOne)在根據(jù)主鍵ID查詢(xún)實(shí)體對(duì)象的時(shí)候偶爾會(huì)出現(xiàn)null的問(wèn)題記錄
- 詳解mybatis plus使用insert沒(méi)有返回主鍵的處理
- MybatisPlus中插入數(shù)據(jù)后獲取該對(duì)象主鍵值的實(shí)現(xiàn)
- mybatisplus?復(fù)合主鍵(多主鍵)?CRUD示例詳解
- mybatis-plus實(shí)體類(lèi)主鍵策略有3種(小結(jié))
- mybatis-plus id主鍵生成的坑
- mybatis-plus主鍵生成策略
- 淺談MyBatis Plus主鍵設(shè)置策略
相關(guān)文章
Spring Security實(shí)現(xiàn)基于角色的訪(fǎng)問(wèn)控制框架
Spring Security是一個(gè)功能強(qiáng)大的安全框架,提供了基于角色的訪(fǎng)問(wèn)控制、身份驗(yàn)證、授權(quán)等安全功能,可輕松保護(hù)Web應(yīng)用程序的安全,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2023-04-04java將指定目錄下文件復(fù)制到目標(biāo)文件夾的幾種小方法
在Java中有多種方法可以實(shí)現(xiàn)文件的復(fù)制,這篇文章主要給大家介紹了關(guān)于java將指定目錄下文件復(fù)制到目標(biāo)文件夾的幾種小方法,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01pagehelper插件顯示total為-1或1的問(wèn)題
這篇文章主要介紹了pagehelper插件顯示total為-1或1,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-09Apache Calcite進(jìn)行SQL解析(java代碼實(shí)例)
Calcite是一款開(kāi)源SQL解析工具, 可以將各種SQL語(yǔ)句解析成抽象語(yǔ)法樹(shù)AST(Abstract Syntax Tree), 之后通過(guò)操作AST就可以把SQL中所要表達(dá)的算法與關(guān)系體現(xiàn)在具體代碼之中,今天通過(guò)代碼實(shí)例給大家介紹Apache Calcite進(jìn)行SQL解析問(wèn)題,感興趣的朋友一起看看吧2022-01-01AOP之事務(wù)管理<aop:advisor>的兩種配置方式
這篇文章主要介紹了AOP之事務(wù)管理<aop:advisor>的兩種配置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11Idea2020 無(wú)法share項(xiàng)目到svn的解決方法
這篇文章主要介紹了Idea2020 無(wú)法share項(xiàng)目到svn的解決方法,需要的朋友可以參考下2020-09-09Java Tree結(jié)構(gòu)數(shù)據(jù)中查找匹配節(jié)點(diǎn)方式
這篇文章主要介紹了Java Tree結(jié)構(gòu)數(shù)據(jù)中查找匹配節(jié)點(diǎn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09