时间:2021-05-19
一、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 添加相关的连接配置信息
2.3、applicationContext.xml 添加dataSource设置
2.4、在Oracle中创建表数据及序列
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配置
本质:
其实在Oracle数据库中进行新增数据首先在数据库中先执行
select seq_user.nextval from dual;这样获取下一个主键的序列,然后再执行插入操作
另外:
实际开发中可能会有很多个实体类,所以在每个实体类上都加上@KeySequence,显得很繁琐
假如需要多个实体公用同一个序列
可以将@keySequence 定义在父类中, 可实现多个子类对应的多个表公用一个 Sequence
到此这篇关于浅谈MyBatis-Plus学习之Oracle的主键Sequence设置的方法的文章就介绍到这了,更多相关Mybatis-Plus Oracle 主键Sequence内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
已有的springcloud+mybatis项目升级为mybatis-plus项目模块目录将mybatis依赖替换为mybatis-plus修改配置文件实体类如
mybatis-plus版本不兼容问题1,mybatis-plus版本中存在一个问题。2,mybatis-plus-extension版本为v3.2.1.1-S
Mybatis-Plus的配置1.Maven插件velocity-engine-core是mybatis-plus自动生成代码所依赖的模板(不用自动生成代码功能
1、使用mybatis-plus自身的查询构造去,只需要在全局配置中添加如下配置mybatis-plus:mapper-locations:classpath:
搭建MyBatis-Plus框架并进行数据库添加MyBatis-Plus(简称MP)是一个MyBatis的增强工具,在MyBatis的基础上只做增强不做改变,为