orcal添加序列让主键的自动增长

ORCACLE创建表ID后不会自动增长,可以通过添加序列实现表ID自动增长

表结构

--创建删除中间表
create table entity
(  ID          NUMBER,
   PRODUCT_ID  NUMBER,
   SYNC_ID     NUMBER
   );

创建表结构序列的时候:

  1. 命名结构:SEQ_表名_表字段,如上entity表需要对ID字段实现自动增长,名称为SEQ_ENTITY_ID
  2. 开始于:初始值(即产生的第一个值),默认为1
  3. 增量:序列的步长,如果省略,则默认为1,如果出现负值,则代表Oracle序列的值是按照此步长递减的。
  4. 最小值:序列生成器能产生的最小值,对于递增Oracle序列,能够产生的最大值是10的27次方;对于递减序列,最大值是-1
  5. 最大值:序列生成器能产生的最大值,对于递增Oracle序列,能够产生的最大值是10的27次方;对于递减序列,最大值是-1
  6. 循环:表示当序列生成器的值达到限制值后是否循环。如果循环,则当递增序列达到最大值时,循环到最小值;对于递减序列达到最小值时,循环到最大值。如果不循环,达到限制值后,继续产生新值就会发生错误。
  7. 排序:按顺序生成。此条件适用于RAC环境。

序列还有其他两个属性:

NEXTVAL :返回序列中下一个有效的值.调用NEXTVAL将生成序列中的下一个序列号.

CURRVAL :中存放序列的当前值,调用CURRVAL不会产生序列的下一个值.

使用语句:select 序列.nextval from dual

                  select 序列.currval from dual

分布式下数据同步确保一致性的:

表结构中有个SYNC_ID字段 ,添加一个SEQ_ENTITY_SYNC_ID序列能够确保分布式系统的数据同步。

 

查询所有序列

SELECT * FROM USER_OBJECTS     可以查看用户拥有的序列

SELECT * FROM USER_SEQUENCES   可以查看序列的设置

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值