亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

淺談MyBatis-Plus學(xué)習(xí)之Oracle的主鍵Sequence設(shè)置的方法

 更新時間:2020年08月26日 10:51:28   作者:hjjay  
這篇文章主要介紹了淺談MyBatis-Plus學(xué)習(xí)之Oracle的主鍵Sequence設(shè)置的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

一、Oracle的主鍵Sequence設(shè)置簡介

在Oracle數(shù)據(jù)庫中不支持主鍵自增策略,它是通過Sequence序列來進行完成的,因此需要在MP中進行相關(guān)配置

二、相關(guān)配置如下

2.1、pom.xml 添加相關(guān)依賴

注意:由于oracle的授權(quán)問題,沒辦法從maven倉庫中下載,因此可以手動從oracle官網(wǎng)中下載,并本地打包到倉庫中

<!-- Oracle驅(qū)動: 因為Oracle授權(quán)的問題,不能從Maven的倉庫中下載到Oracle驅(qū)動 -->
 <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、實體相關(guān)配置

注意兩點:

@KeySequence(value="seq_user",clazz=Integer.class) //value為數(shù)據(jù)庫中生成的序列名,class指主鍵屬性類型

 @TableId(type=IdType.INPUT)  //注意主鍵類型要指定為Input

@KeySequence(value="seq_user",clazz=String.class) //value為數(shù)據(jù)庫中生成的序列名,class指主鍵屬性類型
public class User {
 @TableId(type=IdType.INPUT) //注意主鍵類型要指定為Input
 private String id;
 @TableField(fill=FieldFill.INSERT_UPDATE) //當(dāng)插入和更新都會進行字段的填充
 private String name;
 @TableLogic //標(biāo)志是一個邏輯標(biāo)識符號
 private Integer deleteFlag;
}

2.6、applicationContext.xml配置

 <!-- mybatis-plus全局配置策略 ,這樣避免重復(fù)在每一個實體中使用注解進行配置-->
 <bean id="globalConfiguration" class="com.baomidou.mybatisplus.entity.GlobalConfiguration">
 <property name="dbColumnUnderline" value="true"></property> <!-- 2.3版本后默認配置數(shù)據(jù)庫下劃線-->
 <!-- 指定數(shù)據(jù)庫ID生成策略 0:數(shù)據(jù)庫自增-->
 <property name="idType" value="0"></property>
 <!-- 指定數(shù)據(jù)庫表前綴 -->
 <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ì):

其實在Oracle數(shù)據(jù)庫中進行新增數(shù)據(jù)首先在數(shù)據(jù)庫中先執(zhí)行

select seq_user.nextval from dual;這樣獲取下一個主鍵的序列,然后再執(zhí)行插入操作

另外:

實際開發(fā)中可能會有很多個實體類,所以在每個實體類上都加上@KeySequence,顯得很繁瑣

假如需要多個實體公用同一個序列

可以將@keySequence 定義在父類中, 可實現(xiàn)多個子類對應(yīng)的多個表公用一個 Sequence

到此這篇關(guān)于淺談MyBatis-Plus學(xué)習(xí)之Oracle的主鍵Sequence設(shè)置的方法的文章就介紹到這了,更多相關(guān)Mybatis-Plus Oracle 主鍵Sequence內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Spring Security實現(xiàn)基于角色的訪問控制框架

    Spring Security實現(xiàn)基于角色的訪問控制框架

    Spring Security是一個功能強大的安全框架,提供了基于角色的訪問控制、身份驗證、授權(quán)等安全功能,可輕松保護Web應(yīng)用程序的安全,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2023-04-04
  • java將指定目錄下文件復(fù)制到目標(biāo)文件夾的幾種小方法

    java將指定目錄下文件復(fù)制到目標(biāo)文件夾的幾種小方法

    在Java中有多種方法可以實現(xiàn)文件的復(fù)制,這篇文章主要給大家介紹了關(guān)于java將指定目錄下文件復(fù)制到目標(biāo)文件夾的幾種小方法,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-01-01
  • Java中的@PreAuthorize注解使用詳解

    Java中的@PreAuthorize注解使用詳解

    這篇文章主要介紹了Java中的@PreAuthorize注解使用詳解,@PreAuthorize注解會在方法執(zhí)行前進行權(quán)限驗證,支持Spring EL表達式,它是基于方法注解的權(quán)限解決方案,需要的朋友可以參考下
    2023-10-10
  • pagehelper插件顯示total為-1或1的問題

    pagehelper插件顯示total為-1或1的問題

    這篇文章主要介紹了pagehelper插件顯示total為-1或1,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-09-09
  • SpringMVC之@InitBinder注解詳解

    SpringMVC之@InitBinder注解詳解

    這篇文章主要介紹了SpringMVC之@InitBinder注解詳解,springmvc并不是能對所有類型的參數(shù)進行綁定的,如果對日期Date類型參數(shù)進行綁定,就會報錯IllegalStateException錯誤,需要的朋友可以參考下
    2024-01-01
  • Apache Calcite進行SQL解析(java代碼實例)

    Apache Calcite進行SQL解析(java代碼實例)

    Calcite是一款開源SQL解析工具, 可以將各種SQL語句解析成抽象語法樹AST(Abstract Syntax Tree), 之后通過操作AST就可以把SQL中所要表達的算法與關(guān)系體現(xiàn)在具體代碼之中,今天通過代碼實例給大家介紹Apache Calcite進行SQL解析問題,感興趣的朋友一起看看吧
    2022-01-01
  • AOP之事務(wù)管理<aop:advisor>的兩種配置方式

    AOP之事務(wù)管理<aop:advisor>的兩種配置方式

    這篇文章主要介紹了AOP之事務(wù)管理<aop:advisor>的兩種配置方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • Idea2020 無法share項目到svn的解決方法

    Idea2020 無法share項目到svn的解決方法

    這篇文章主要介紹了Idea2020 無法share項目到svn的解決方法,需要的朋友可以參考下
    2020-09-09
  • Java Tree結(jié)構(gòu)數(shù)據(jù)中查找匹配節(jié)點方式

    Java Tree結(jié)構(gòu)數(shù)據(jù)中查找匹配節(jié)點方式

    這篇文章主要介紹了Java Tree結(jié)構(gòu)數(shù)據(jù)中查找匹配節(jié)點方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • java線程組構(gòu)造方法源碼解析

    java線程組構(gòu)造方法源碼解析

    這篇文章主要為大家介紹了java線程組構(gòu)造方法源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08

最新評論