设为首页 收藏本站
查看: 1018|回复: 0

[经验分享] DB2序列 自增列 解决之Sequence 对象

[复制链接]

尚未签到

发表于 2016-11-16 09:22:15 | 显示全部楼层 |阅读模式
  
现在,我想要简要地来介绍一下 Sequence 对象以及如何用它们来代替 Identity 列。我们还将介绍版本 8 中一些用以使用 Identity 列的新功能。
我的上两个专栏中已经介绍到了与版本 8 功能相关的主题。我们可能需要在今天设计的数据库和应用程序中考虑这些功能。我们已经谈论了新的数据分区的辅助索引和附加的索引修改。在上一期中,我们了解了 DSSIZE 如何可以影响今后的分区策略。现在,我想要简要地来介绍一下 Sequence 对象以及如何用它们来代替 Identity 列。我们还将介绍版本 8 中一些用以使用 Identity 列的新功能。
数字生成问题
   过去的许多应用程序都需要能够生成序号(例如获取下一个可用的帐号)。问题是该工作通常是通过用单个控制表存储这些数字,然后用可重复读(Repeatable Read)的 SELECT MAX 在随后的 INSERT 中检索并使用该数字来完成的。常常有多个事务需要使用该表,而这就导致了应用程序中无法解决的单点竞争。这是由于每次只有一个事务可以检索下一值,因为事务必须锁定该表以使数字增量。请参阅图 1。
DSC0000.jpg
  在过去多年中曾经尝试过许多创造性的解决方案,例如使用行级的锁定,但是这些技术产生的系统开销加上成千上万个并发事务间的冲突仍然会导致性能瓶颈。如果用于数据共享的环境中,其中将有多个成员使用该表,那么它也会导致单点故障并且产生巨大的锁定开销。

DSC0001.jpg
DSC0002.jpg




Identity 列
   因而在较晚的版本 6 中就出现了 Identity 列,用以解决前面提到的问题。如果一个表指派了 Identity 列,那么当向该表插入一行时,将根据 Identity 列的定义(START WITH 和 INCREMENT BY 值)来填充它。虽然使用 Identity 列要远胜于使用单个控制表,但是 Identity 列在使用方面却非常有限并且存在管理问题。
   在版本 8 之前,Identity 列还带来了一些问题,例如:

  • 如何获得 Identity 列的值来填充 RI 有关的表?
  • 如何在插入之前获取值?
  • 如何重新设置或更改 Identity 列的值?
   这还仅仅只是一部分问题。许多公司围绕这些问题开发了一种方法,他们从表中删除 Identity 列然后创建一个只含 Identity 列及其生成值的表。因此,上述问题,例如重新开始 Identity 列的值或填充 RI 有关的表,都可以通过使 Identity 列与表分离而得到解决。该技术仍然允许由 DB2 来填充 Identity 列的值,并且减少了许多限制。但还是必须要对该表进行填充、访问和维护,并且它无法解决 Identity 列的所有问题以及无法完全开发与由 DB2 执行数字生成相关的潜在性能。图 2 是一个展示如何使用该技术的例子。
DSC0003.jpg
   版本 8 已经缓解了上述 Identity 列的部分问题,例如使用 SELECT 功能中的新的 INSERT 进行插入之前可以获得 Identity 列的值。下面这个例子展示了如何在插入时使用该功能来获取 Identity 列的值。
    (假定所创建的表以自动生成的 ACCT_ID 为 Identity 列)
例 1 
   SELECT ACCT_ID 
   FROM FINAL TABLE 
      (INSERT INTO UID1.ACCOUNT (NAME, TYPE, BALANCE) 
      VALUES ('Master Card', 'Credit', 50000) ) 


   版本 8 中还可以更改其他一些值,例如: 

CACHE/NO CACHE 
   CYCLE/NO CYCLE 
   MINVALUE 
   MAXVALUE 
   INCREMENT BY 
   RESTART WITH

   这些执行更改的功能,特别是 RESTART WITH,给 Identity 列的使用带来了更大的灵活性。然而,这些功能是定义在单个表上的,这一本质使它们仍然受到了一些限制,而且应用程序对它们的利用也仍然有限。此外,这些更改还将导致表空间被置于 REORG 暂挂状态,从而导致表无法获得表空间。






Sequence 对象
   在首次宣布 Sequence 对象时,我认为它们只是为了将应用程序从其他数据库移植到 DB2 而向 DB2 添加的另一功能。但是我越是深入地研究它们,就越是开始喜欢这些新的对象了,因为它们消除了我们对于 Identity 列的许多限制,而且它们还具有许多独特且有用的功能。它还向我们提供了数字生成的另一备选方法。
  Sequence 对象是用户定义的对象,用以根据其创建规范生成数值序列。 它们提供一个由 DB2 生成的增量计数器,并且与 Identity 列十分相似。可将 Identity 列当作一种特殊的 Sequence 对象;但是,sequence 列与表是分开的。
   Sequence 对象值可因为各种理由而用于应用程序中。这样做有一些好处,例如:

  • 无需等待值的增加;
  • 独立的连续数字生成对象(不与表关联);
  • 递增或递减地生成数字;
  • 用于从其他数据库移植应用程序;
  • 可以生成键,用以跨多个表(RI 或相关的应用程序)协调各键。
    序列名由两部分组成:128 字节的模式名和 128 字节的标识符。它们是通过新的 CREATE SEQUENCE 语句创建的,并且其所有属性完全都是由用户定义的(您也可以使用默认值)。Sequence 对象中的值可以是任何数字数据类型。初值是用 START WITH 值定义的,而增量则是由 INCREMENT BY(递增的或递减的)定义的。可以缓存这些值或按请求次序来生成。


   下面这个例子展示了一个 Sequence 对象的创建及其简单用法。 

CREATE SEQUENCE ACCOUNT_SEQ 
      AS INTEGER 
      START WITH 1 
      INCREMENT BY 10 
      CYCLE 
      CACHE 20 

   正如您所看到的,Sequence 对象的使用方法与许多人对于 Identity 列的使用比较相似。但是这更为有效,而且 Sequence 对象有一些极佳的使用优点。例如可以使用 NEXT VALUE FOR 和 PREVIOUS VALUE FOR。NEXTVALUE FOR 将为 Sequence 对象生成并返回下一值。而 PREVIOUS VALUE FOR 将为 Sequence 对象生成并返回前一值。这些语句可用于下列地方:


  • SELECT 和 SELECT INTO 语句;
  • INSERT 语句里面的 fullselect 的 SELECT 从句;
  • UPDATE 语句里面的 SET 从句(搜索或定位);
  • SET 主变量;
  • VALUES 或 VALUES INTO;
  • CREATE PROCEDURE、FUNCTION、TRIGGER。
   下面的例子(右边的表 2)展示了这些语句的用法: 
    假定 ACCT_SEQ 为 START WITH 10 INCREMENT BY 10 

   正如您所看到的,使用 Sequence 对象代替 Identity 列有许多好处。下面是两者的一个简单比较。 


Sequence 对象与 Identity 列
Sequence 对象Identity 列(带有 V8 功能)
单独的 Sequence 对象是在用户请求时创建的由 DB2 生成/维护和填充的内部 Sequence 对象
可用于它们所选择的任何目的,并且存在有多个与特定的表相关联,并且只能有一个
循环(CYCLE)将回绕和重复,并且无需进行惟一性考虑如果惟一索引在 Identity 列上并且创建了复制,那么循环(CYCLE)可能会产生问题
当用于填充表时,后来可被更新如果是 GENERATED ALWAYS,就无法被更新
可以更改(ALTER)Sequence 对象的属性。 
还可以进行注释(COMMENT)以及授予/撤销(GRANT/REVOKE)权限
只能更改表(ALTER TABLE)(如果向已填充的表添加 Identity 列,将被置于 REORG 暂挂状态)
可被删除不能从表中删除*
支持 NEXT VALUE FOR EXPRESSION 和 PREVIOUS VALUE FOR EXPRESSION必须使用 ID_VAL_LOCAL 并且只返回用户提交(commit)范围内的最后值
如果今后设计中使用 Sequence 对象比使用 Identity 列更好,那么在选择 Identity 列时就要考虑仔细。如果它们是在已填充的表上定义的并且需要被删除,那么必须删除表然后重新创建。这对于高效环境中的大型表可能是一个大问题。






结束语
   Identity 列和 Sequence 对象在我们的设计中都占有一席之地。鉴于它们都可以达到相同的目的 —— 生成序号,所以应该由您来选择哪一个更适合您。这将取决于您对生成的数字所需的灵活性,以及应用程序将如何使用这些数字。


关于作者
Susan Lawson 是 YL&A 公司的负责人。她还是“DB2 Answers!”、“DB2 High Performance Design and Tuning”、“DB2 for OS/390 DBA Certification Guide”、“DB2 UDB V7 Family Reference Guide”和“and "DB2 UDB V7 Application Certification Guide”的合著者。她是一位 DB2 Certified Solutions Expert 和 IBM Gold Consultant。她从事 DB2 方面的工作已经超过 14 年了并且帮助开发和调优了一些世界上最大和最复杂的数据库系统。
版型乱了,原文地址:http://www.ibm.com/developerworks/cn/data/library/techarticles/idugnov03/article09.html
还有更牛逼的文章:http://www.ibm.com/developerworks/cn/data/library/techarticles/dm-0407zhang/

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-301018-1-1.html 上篇帖子: 在DB2中创建第一个触发器 下篇帖子: DB2 Hibernate 查询 SQLCODE: -418, SQLSTATE: 42610, SQLERRMC: null
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表