MyBatis-Plus中如何设置主键甲骨文的序列

  介绍

MyBatis-Plus中如何设置主键甲骨文的序列?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。


在甲骨文数据库中不支持主键自增策略,它是通过序序列来进行完成的,因此需要在议员中进行相关配置

<强>

<强> 2.1,砰的一声。xml添加相关依赖

注意:由于甲骨文的授权问题,没办法从maven仓库中下载,因此可以手动从oracle官网中下载,并本地打包到仓库中

& lt; !——甲骨文驱动:因为Oracle授权的问题,不能从Maven的仓库中下载到Oracle驱动——比;   & lt; dependency>   & lt; groupId> com.oracle   & lt; artifactId> ojdbc14   & lt; version> 10.2.0.4.0   & lt;/dependency>

<强> 2.2,db。属性添加相关的连接配置信息

orcl.driver=oracle.jdbc.OracleDriver   orcl.url=jdbc: oracle:薄:@localhost: 1521:议员   orcl.username=用户名   orcl.password=1234

<强> 2.3,applicationContext。xml添加数据源设置

& lt; !——甲骨文——比;   & lt; bean id=癲ataSource"类=癱om.mchange.v2.c3p0.ComboPooledDataSource"比;   & lt;属性名=癲riverClass"值=https://www.yisu.com/zixun/" $ {orcl.driver} ">   <属性名=" jdbcUrl " value=" $ {orcl.url} ">   <属性名="用户" value=" $ {orcl.username} ">   <属性名="密码" value=" $ {orcl.password} ">   

<强> 2.4,在甲骨文中创建表数据及序列

创建表tbl_user (
  身份证号码(10),
  名字varchar2 (32),
  delete_flag数量(10)
  )
  ——创建序列
  创建序列seq_user开始1;

<强> 2.5,实体相关配置

注意两点:

@KeySequence (value=https://www.yisu.com/zixun/皊eq_user clazz=Integer.class)//值为数据库中生成的序列名,类指主键属性类型

, @TableId(类型=IdType.INPUT),//注意主键类型要指定为输入

@KeySequence (value=https://www.yisu.com/zixun/皊eq_user clazz=String.class)//值为数据库中生成的序列名,类指主键属性类型   公开课用户{   @TableId(类型=IdType.INPUT)//注意主键类型要指定为输入   私人字符串id;   @TableField(填补=FieldFill.INSERT_UPDATE)//当插入和更新都会进行字段的填充   私人字符串名称;   @TableLogic//标志是一个逻辑标识符号   私人整数deleteFlag;   }

<强> 2.6,applicationContext。xml配置

  
  
  <属性名=" idType " value=" 0 "> 
  
  <属性名=" tablePrefix " value=": tbl_ "> 
  
  <属性名=" keyGenerator“ref=" oracleKeyGenerator "> 
  
  
  
    

本质:

其实在甲骨文数据库中进行新增数据首先在数据库中先执行

选择seq_user。从双nextval;这样获取下一个主键的序列,然后再执行插入操作

另外:

实际开发中可能会有很多个实体类,所以在每个实体类上都加上@KeySequence,显得很繁琐

假如需要多个实体公用同一个序列

可以将@KeySequence定义在父类中,可实现多个子类对应的多个表公用一个序列

MyBatis-Plus中如何设置主键甲骨文的序列