【转自Oracle ACS--惜总】正常关闭数据库sequence cache不为0 sequence不跳跃

原文网址: http://www.xifenfei.com/5831.html

 

联系:手机(13429648788) QQ(107644445)

链接:http://www.xifenfei.com/5831.html

标题:正常关闭数据库sequence cache不为0 sequence不跳跃

作者:惜分飞©版权所有[文章允许转载,但必须以链接方式注明源地址,否则追究法律责任.]

在Oracle中sequence使用很频繁,而大部分使用都配合了cache一起使用,那在sequence+cache一起使用的过程中,如果数据库正常关闭sequence.nextval如果变化,如果数据库异常关闭sequence.nextval又如何变化?这里通过试验进行了证明,结论为:在有cache的sequence中,正常关闭数据库sequence不会出现跳跃,异常关闭数据库很可能导致sequence出现跳跃
创建sequence测试

[oracle@localhost ~]$ sqlplus / as sysdba
 
SQL*Plus: Release 11.2.0.4.0 Production on Sun Apr 5 15:44:23 2015
 
Copyright (c) 1982, 2013, Oracle.  All rights reserved.
 
 
Connected to :
Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
 
SQL> select sysdate "www.xifenfei.com" from dual;
 
www.xifen
---------
05-APR-15
 
SQL> create sequence seq_xifenfei
   2   minvalue 1
   3   maxvalue 100000
   4   start with 1
   5   increment by 1
   6   cache 100;
 
Sequence created.
 
SQL> select SEQ_XIFENFEI.nextval from dual;
 
    NEXTVAL
----------
          1
 
SQL> /
 
    NEXTVAL
----------
          2
 
SQL> /
 
    NEXTVAL
----------
          3
 
SQL> select object_id from dba_objects where object_name= 'SEQ_XIFENFEI' ;
 
  OBJECT_ID
----------
      87549
 
SQL>  SELECT MINVALUE,HIGHWATER,INCREMENT$, CYCLE#, ORDER $,CACHE from seq$ where obj#=87549;
 
   MINVALUE  HIGHWATER INCREMENT$     CYCLE#     ORDER $      CACHE
---------- ---------- ---------- ---------- ---------- ----------
          1        101          1          0          0        100

这里创建了一个名为SEQ_XIFENFEI的sequence,并且nextval已经查询到3,而且cache值设置为100,object_id为87549.

正常关闭数据库测试sequence.nextval变化

SQL> shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> startup
ORACLE instance started.
 
Total System Global Area 1570009088 bytes
Fixed Size                  2253584 bytes
Variable Size             469765360 bytes
Database Buffers         1090519040 bytes
Redo Buffers                7471104 bytes
Database mounted.
Database opened.
SQL> SELECT MINVALUE,HIGHWATER,INCREMENT$, CYCLE#, ORDER $,CACHE from seq$ where obj#=87549;
 
   MINVALUE  HIGHWATER INCREMENT$     CYCLE#     ORDER $      CACHE
---------- ---------- ---------- ---------- ---------- ----------
          1          4          1          0          0        100
 
SQL> select SEQ_XIFENFEI.nextval from dual;
 
    NEXTVAL
----------
          4
 
SQL> SELECT MINVALUE,HIGHWATER,INCREMENT$, CYCLE#, ORDER $,CACHE from seq$ where obj#=87549;
 
   MINVALUE  HIGHWATER INCREMENT$     CYCLE#     ORDER $      CACHE
---------- ---------- ---------- ---------- ---------- ----------
          1        104          1          0          0        100

正常关闭数据库启动后,sequence.nextval依然在上次基础之上增加,并为出现跳跃现象.

异常关闭数据库测试sequence.nextval变化

SQL> shutdown  abort;
ORACLE instance shut down.
SQL> startup
ORACLE instance started.
 
Total System Global Area 1570009088 bytes
Fixed Size                  2253584 bytes
Variable Size             469765360 bytes
Database Buffers         1090519040 bytes
Redo Buffers                7471104 bytes
Database mounted.
Database opened.
SQL> SELECT MINVALUE,HIGHWATER,INCREMENT$, CYCLE#, ORDER $,CACHE from seq$ where obj#=87549;
 
   MINVALUE  HIGHWATER INCREMENT$     CYCLE#     ORDER $      CACHE
---------- ---------- ---------- ---------- ---------- ----------
          1        104          1          0          0        100
 
SQL> select SEQ_XIFENFEI.nextval from dual;
 
    NEXTVAL
----------
        104
 
SQL> SELECT MINVALUE,HIGHWATER,INCREMENT$, CYCLE#, ORDER $,CACHE from seq$ where obj#=87549;
 
   MINVALUE  HIGHWATER INCREMENT$     CYCLE#     ORDER $      CACHE
---------- ---------- ---------- ---------- ---------- ----------
          1        204          1          0          0        100

异常关闭数据库启动后,sequence.nextvla发生跳跃从本该5直接跳跃到了104.

跟踪数据库正常关闭过程

SQL> alter session set events '10046 trace name context forever, level 4' ;
 
Session altered.
 
SQL> shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> startup
ORACLE instance started.
 
Total System Global Area 1570009088 bytes
Fixed Size                  2253584 bytes
Variable Size             469765360 bytes
Database Buffers         1090519040 bytes
Redo Buffers                7471104 bytes
Database mounted.
Database opened.
 
SQL>  SELECT MINVALUE,HIGHWATER,INCREMENT$, CYCLE#, ORDER $,CACHE from seq$ where obj#=87549;
 
   MINVALUE  HIGHWATER INCREMENT$     CYCLE#     ORDER $      CACHE
---------- ---------- ---------- ---------- ---------- ----------
          1        105          1          0          0        100
 
SQL> select SEQ_XIFENFEI.nextval from dual;
 
    NEXTVAL
----------
        105
 
SQL> SELECT MINVALUE,HIGHWATER,INCREMENT$, CYCLE#, ORDER $,CACHE from seq$ where obj#=87549;
 
   MINVALUE  HIGHWATER INCREMENT$     CYCLE#     ORDER $      CACHE
---------- ---------- ---------- ---------- ---------- ----------
          1        205          1          0          0        100

再次证明了正常关闭数据库后,sequence.nextval未发生跳跃.

分析trace文件

PARSING IN CURSOR #139819144537744 len=129 dep=1 uid=0 oct=6 lid=0 tim=1428220381105111
hv=2635489469 ad= 'bc6e6c30' sqlid= '4m7m0t6fjcs5x'
update seq $ set increment$=:2,minvalue=:3,maxvalue=:4,cycle #=:5,order$=:6,cache=:7,
highwater=:8,audit$=:9,flags=:10 where obj #=:1
END OF STMT
BINDS #139819144537744:
  Bind #0
   oacdty=02 mxl=22(02) mxlc=00 mal=00 scl=00 pre=00
   oacflg=10 fl2=0001 frm=00 csi=00 siz=24 off=0
   kxsbbbfp=bc41e288  bln=22  avl=02  flg=09
   value=1
  Bind #1
   oacdty=02 mxl=22(02) mxlc=00 mal=00 scl=00 pre=00
   oacflg=10 fl2=0001 frm=00 csi=00 siz=24 off=0
   kxsbbbfp=bc41e29a  bln=22  avl=02  flg=09
   value=1
  Bind #2
   oacdty=02 mxl=22(02) mxlc=00 mal=00 scl=00 pre=00
   oacflg=10 fl2=0001 frm=00 csi=00 siz=24 off=0
   kxsbbbfp=bc41e2ac  bln=22  avl=02  flg=09
   value=100000
  Bind #3
   oacdty=02 mxl=22(22) mxlc=00 mal=00 scl=00 pre=00
   oacflg=00 fl2=0001 frm=00 csi=00 siz=48 off=0
   kxsbbbfp=7f2a2edc2da8  bln=22  avl=01  flg=05
   value=0
  Bind #4
   oacdty=02 mxl=22(22) mxlc=00 mal=00 scl=00 pre=00
   oacflg=00 fl2=0001 frm=00 csi=00 siz=0 off=24
   kxsbbbfp=7f2a2edc2dc0  bln=22  avl=01  flg=01
   value=0
  Bind #5
   oacdty=02 mxl=22(02) mxlc=00 mal=00 scl=00 pre=00
   oacflg=10 fl2=0001 frm=00 csi=00 siz=24 off=0
   kxsbbbfp=bc41e2be  bln=22  avl=02  flg=09
   value=100
  Bind #6
   oacdty=02 mxl=22(03) mxlc=00 mal=00 scl=00 pre=00
   oacflg=10 fl2=0001 frm=00 csi=00 siz=24 off=0
   kxsbbbfp=bc41e2d0  bln=22  avl=03  flg=09
   value=105     <     ----SEQ_XIFENFEI.nextval值
  Bind #7
   oacdty=01 mxl=32(32) mxlc=00 mal=00 scl=00 pre=00
   oacflg=10 fl2=0001 frm=01 csi=852 siz=32 off=0
   kxsbbbfp=bc41e2e2  bln=32  avl=32  flg=09
   value= "--------------------------------"
  Bind #8
   oacdty=02 mxl=22(22) mxlc=00 mal=00 scl=00 pre=00
   oacflg=00 fl2=0001 frm=00 csi=00 siz=48 off=0
   kxsbbbfp=7f2a2edc2d60  bln=22  avl=01  flg=05
   value=0
  Bind #9
   oacdty=02 mxl=22(22) mxlc=00 mal=00 scl=00 pre=00
   oacflg=00 fl2=0001 frm=00 csi=00 siz=0 off=24
   kxsbbbfp=7f2a2edc2d78  bln=22  avl=04  flg=01
   value=87549                             <---这个就是我们的sequence(SEQ_XIFENFEI)
EXEC #139819144537744:c=0,e=650,p=0,cr=1,cu=2,mis=0,r=1,dep=1,og=4,plh=1935744642,tim=1428220381108066
CLOSE #139819144537744:c=0,e=2,dep=1,type=3,tim=1428220381108119

这里我们找出来了为什么数据库正常关闭sequence.nextval在有cache的情况下,未发生跳跃:因为在数据库正常关闭的情况下,会触发一个update seq$的操作,把当前的sequence.nextval的值更新到seq$.highwater中,从而使得sequence在有cache的情况下,数据库正常关闭未出现nextval跳跃(currval也同样不跳跃);而在数据库异常关闭之时,数据库不能及时将sequence.nextval更新到eq$.highwater从而引起sequence cache中的值丢失,从而可能出现了sequence使用cache导致跳跃的情况
关于另外一篇关于sequence cache减小update seq$频率的测试,请见:关于oracle sequence一些小测试

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: openacs-bin-0.5是一种开放源代码的轻量级应用程序,用于构建和管理网络应用程序的基础架构。它是一个基于Web的应用程序服务器,可以协调许多不同的组件和模块来实现一个完整的网站或在线应用程序。 openacs-bin-0.5提供了一套功能强大的工具和库,用于开发和部署具有动态内容的网站。它支持多种数据库和操作系统,并提供了一套完整的工作流程管理方法。它的设计目标是提供一个灵活且可扩展的平台,可以满足不同类型的应用程序需求。 与其他开源应用程序服务器相比,openacs-bin-0.5具有许多优势。首先,它具有强大的安全性功能,可以确保应用程序的数据和用户信息受到保护。其次,它提供了一套完整的开发工具,使开发人员能够轻松创建和维护复杂的应用程序。此外,它还有一个活跃的开发社区,可以提供技术支持和交流。 之,openacs-bin-0.5是一个强大而灵活的应用程序服务器,可以帮助开发人员快速构建并管理各种类型的网络应用程序。它在安全性、功能性和可扩展性方面具有明显优势,是一个值得尝试的开源软件。 ### 回答2: openacs-bin-0.5是一个开源项目,它是基于OpenACS(Open Architecture Community System)平台的一个二进制软件包。OpenACS是一个用于构建基于Web的应用程序的框架和工具集。openacs-bin-0.5提供了一系列功能和模块,用于快速搭建和管理网站、社区和在线应用。 openacs-bin-0.5包含了许多常用的开发工具和模板,可以帮助开发人员快速开始项目,并提供了一些常用功能的实现,例如用户管理、权限控制、内容管理、论坛、电子商务等。开发人员可以使用openacs-bin-0.5来加速项目的开发和部署过程,同时还可以根据需要自定义和扩展。 openacs-bin-0.5还提供了一些简单易用的管理工具,用于配置和管理网站、用户和内容。管理员可以使用这些工具来管理用户权限、发布和管理内容、监控网站性能等。这些工具可以帮助管理员轻松地管理和维护网站,提高效率和用户体验。 openacs-bin-0.5还具有良好的可扩展性和可定制性。开发人员可以根据自己的需求进行二次开发和定制,添加新功能和模块,以满足特定的业务需求。同时,openacs-bin-0.5也拥有活跃的开发社区和用户群体,提供技术支持和共享资源。 而言之,openacs-bin-0.5是一个基于OpenACS平台的二进制软件包,它提供了许多有用的开发工具和模块,用于快速构建和管理Web应用程序。它具有简单易用的管理工具和良好的可扩展性,可以帮助开发人员和管理员快速部署和维护网站和在线应用。 ### 回答3: openacs-bin-0.5是一个开源软件包,用于构建基于网络的应用程序和管理网站内容的工具集。 openacs-bin-0.5提供了一组功能强大的工具和API,使开发人员能够轻松地创建和管理复杂的Web应用程序。它采用了模块化的架构,可以根据需求自由选择和集成不同的模块,如论坛、用户管理、电子商务等,以构建定制化的网站。 该软件包还提供了丰富的管理工具,使网站管理员能够方便地管理网站内容和用户。管理员可以轻松创建、编辑和删除内容,管理用户权限和角色,并监控网站的性能和统计信息。 openacs-bin-0.5是使用Tcl编程语言开发的,它采用了面向对象的编程范式,使开发过程更加高效和灵活。它还支持SQL数据库,并提供了强大的数据库访问接口,以便于应用程序与数据库之间的数据交互。 该软件包还使用了一些安全机制来保护网站和用户的隐私。它支持用户身份验证和授权,以确保只有授权的用户才能访问敏感信息。此外,它还提供了强大的数据安全功能,包括数据加密和访问控制,以保护数据库中的数据。 而言之,openacs-bin-0.5是一个强大的开源软件包,为开发人员和网站管理员提供了一套丰富的工具和功能,帮助他们构建、管理和保护复杂的Web应用程序和网站。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值