【oracle】揭开oracle神秘面纱之Sequence

oracle】揭开oracle神秘面纱之Sequence

最近遇到一个挺让人头疼的问题,往数据库中插入一条数据,时而能插入成功,时而报一个”java.sql.: ORA-00001: 违反唯一约束条件(.E_PK)”的错误.查了查,说是表中的SEQ除了问题,需要把SEQ值的开始值重新设置一下.那么今天就来介绍一个关于这个SEQ.

一.SEQ简介

SEQ的全英文名字叫(顺序),在中叫序列.因为没有自增数据类型,如需生成业务无关的主键列或惟一约束列,可以用序列实现。的是一种数据库对象,它可以生成有序数字【oracle】揭开oracle神秘面纱之Sequence,主要用于主键的自动生成。如果没有,主键的自动生成必须得在代码逻辑里实现oracle sequence失效,大致过程是:获取当前主键值oracle sequence失效,新主键值=当前主键值+增量。如果多个用户同时请求新主键,则会产生并发等待oracle sequence失效,影响效率,就是用来解决这个问题。

二.创建SEQ

createsequence seq_test  
    minvalue 1  
    maxvalue 21  
    start with 1  
    increment by 1  
    cache 20  
    cycle  
    order;

参数介绍:

(1) 1 / :最小值为1

(2) 21 / :最大值为21

oracle sequence失效

(3)start with 1:从1开始计数

(4) by 1:每次增加1

(5)cache 20 / :缓存20个值 /  不缓存

如果缓存,则会有跳号的危险:如果指定cache值,就可以预先在内存里面放置一些,这样存取的快些。内存里面的取完后,自动再取一组到内存。数据库突然不正常down掉,内存中的就会丢失

(6)cycle / : cycle,即如果到达最大值21后,再次从1开始

(7)order  / :  order: are in order of ,按照请求的顺序生成值。如果值为时间戳比较重要,作为主键order选项没什么用

三.修改SEQ

序列()主要用于生成流水号,在应用中经常会用到,特别是作为ID值,拿来做表主键使用较多。但是,有时需要修改序列初始值(START WITH)时,有同仁使用这个语句来修改:alter start 。就会报:ORA-02283: alter 的错误,原因是在 DB中,修改序列没有这样的语法。下面我介绍两种修改SEQ的方法:

1.先删除序列,然后重新创建。这个方法比较方便。

2.通过 By来实现修改初始值。

例如:若序列名称是,初始值是13,而现在要设置初始值为1020, By值为:1007(1020-13)

2.1执行: By 1007;

2.2执行:. From Dual;

2.3执行: By 1;

四.删除SEQ

这个就比较简单了:

drop ;

五.查询SEQ

oracle sequence失效

1 从系统视图中取得所有序列的相关信息。

* from where ='库名 ';

2 从关心的表中提取敏感字段的最大值

(id) from test;

3 将两者对比。或者将上述两个查询连接到一起来查询。如果当前该表没有被插入,并且,近期没有被删除,那么,该max(id)+1=;

六.使用时对系统性能的影响:

1.Seq$基表是记录系统的数据字典表.每次调用,会递归调用更新并 Seq$基表。

2.更新Seq$基表并提交会产生redo log–几百字节,频繁会造成LGWR的压力;过多redo log生成,造成LGWR压力、恢复时费时等。

3.多个会话使用可能出现争用【oracle】揭开oracle神秘面纱之Sequence,等待事件row lock

公告:
1. 本站所有资源来源于用户上传和网络,如有侵权请联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系站长处理!
6. 本站不售卖代码,资源标价只是站长收集整理的辛苦费!如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。
7. 站长QQ号码 2205675299

资源库 - 资源分享下载网 » 【oracle】揭开oracle神秘面纱之Sequence

常见问题FAQ

关于资源售价和售后服务的说明?
本站所有资源的标价均为本站收集资源的辛苦费,不代表资源本身的价值。软件是高智慧高价值的商品,不可能是白菜价。本站资源标价只是赞助费用,收取的赞助费仅用来维持本站的日常运营!毕竟收集整理资料需要投入云计算资源和站长大量的精力。
代码有没有售后服务和技术支持?
由于代码的运行具有不可预见性,本站不保证代码完整可运行,不提供技术支持和售后服务。 本站原创代码都是站长自己开发的,可以有偿提供技术支持服务。 网站里标明【亲测】的代码都是站长亲测过的,其他的代码由于精力有限,没有一一测试,不能保证代码就一定能够使用,更没有技术支持服务,下载前请自行斟酌。
有没有搭建服务?
由于搭建服务比较费时费力,所以本站除了原创代码外均不提供搭建服务。本站分享代码纯属兴趣爱好,不以盈利为目的,请勿咨询有没有搭建服务,谢谢理解。
链接地址失效了怎么办?
请带上资源链接地址联系客服,工作时间内我们看到后将第一时间回复。
关于解压密码
本站资源一般都没有加密,如果发现需要解压密码的,那么就输入 hao.35dc.com 试试。

发表评论

资源库,由老程序员细心甄别、精心筛选,只为提供优质的源码资源

关于我们 联系我们