我在使用 IBM DB2 的自动增量列时遇到了一些麻烦。起初,我的所有列都被定义为GENERATED ALWAYS,但由于我在使用“db2 import ...”命令时遇到了这个问题,我将它们更改为GENERATED BY DEFAULT。这是必要的,因为我需要 ID 保持一致,因为其他表引用它们。因此,不能使用“db2 import ... modified by identityignore ...”。
当我现在导入数据时,ID 被正确插入,但每次我这样做时,我必须记住通过获取最高的 Id+1 为自动增量列设置一个新的开始,并像这样更改列:
SELECT MAX(mycolumn)+ 1 FROM mytable;
ALTER TABLE mytable ALTER COLUMN mycolumn RESTART WITH <above_result>;
如果我忘记了这一点,插入语句将因重复 PK 错误而失败,因为自动增量列是主键。
所以我的问题是:有没有办法找到自动增量列的下一个值,所以我可以编写语句来检查,如果这个值小于 SELECT MAX 并且需要设置?
或者:这整个事情不是像我想象的那么复杂吗?我可以以某种方式导入数据,保留 ID 并让自动增量列仍然按预期工作吗?
蒂姆,我遇到了同样的问题,我需要将身份重新启动到下一个值。我使用的是 db2v9.1。
不幸的是,没有办法自动指定下一个值。根据 DB2 文档,该值应该是“数字常量”。因此我必须做一个选择 max(id),获取值并手动替换它在 alter..restart stmt 中。
我不记得我是否尝试过这个 - 但你可以编写一个 sp,其中 max(id) 设置在一个变量中,并在 alter...restart stmt 中分配该变量。(我无法尝试,因为我不再有权访问任何 db2 数据库)。我怀疑它会起作用。(如果有效,请告诉我:))
DB2 参考:
RESTART 或 RESTART WITH numeric-constant
重置与标识列关联的序列的状态。如果未指定 WITH numeric-constant,则标识列的序列将在最初创建标识列时隐式或显式指定的值重新开始。该列必须存在于指定的表中 (SQLSTATE 42703),并且必须已经使用 IDENTITY 属性 (SQLSTATE 42837) 进行了定义。RESTART 不会更改原始的 START WITH 值。
numeric-constant 是一个精确的数字常量,可以是可以分配给该列的任何正值或负值 (SQLSTATE 42815),小数点右侧不存在非零数字 (SQLSTATE 428FA)。numeric-constant 将用作该列的下一个值。
你不能在 DB2 中使用序列号然后使用序列吗?下一个值()?
在 DB2 中自动生成序列值的链接:http: //www.ibm.com/developerworks/data/library/techarticle/0302fielding/0302fielding.html
你的问题现在可能已经解决了,但是对于所有其他有同样问题的人来说:我可以提供一个解决方案来为所有表获取 max_id +1。唯一的限制是,源列必须是自动增量列 (GENERATED= 'D')。结果集可以通过 clp 或其他查询工具执行。