浅谈MyBatis-Plus学习之Oracle的主键Sequence设置的方法
一、Oracle的主键Sequence设置简介
在Oracle数据库中不支持主键自增策略,它是通过Sequence序列来进行完成的,因此需要在MP中进行相关配置
二、相关配置如下
2.1、pom.xml添加相关依赖
注意:由于oracle的授权问题,没办法从maven仓库中下载,因此可以手动从oracle官网中下载,并本地打包到仓库中
com.oracle ojdbc14 10.2.0.4.0
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设置
2.4、在Oracle中创建表数据及序列
createtabletbl_user( idnumber(10), namevarchar2(32), delete_flagnumber(10) ) --创建序列 createsequenceseq_userstartwith1;
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指主键属性类型 publicclassUser{ @TableId(type=IdType.INPUT)//注意主键类型要指定为Input privateStringid; @TableField(fill=FieldFill.INSERT_UPDATE)//当插入和更新都会进行字段的填充 privateStringname; @TableLogic//标志是一个逻辑标识符号 privateIntegerdeleteFlag; }
2.6、applicationContext.xml配置
本质:
其实在Oracle数据库中进行新增数据首先在数据库中先执行
selectseq_user.nextvalfromdual;这样获取下一个主键的序列,然后再执行插入操作
另外:
实际开发中可能会有很多个实体类,所以在每个实体类上都加上@KeySequence,显得很繁琐
假如需要多个实体公用同一个序列
可以将@keySequence定义在父类中,可实现多个子类对应的多个表公用一个Sequence
到此这篇关于浅谈MyBatis-Plus学习之Oracle的主键Sequence设置的方法的文章就介绍到这了,更多相关Mybatis-PlusOracle主键Sequence内容请搜索毛票票以前的文章或继续浏览下面的相关文章希望大家以后多多支持毛票票!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。