AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 20389
Accepted
Tim Büthe
Tim Büthe
Asked: 2009-06-06 02:11:15 +0800 CST2009-06-06 02:11:15 +0800 CST 2009-06-06 02:11:15 +0800 CST

如何找到自动增量列的下一个生成值?

  • 772

我在使用 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 并让自动增量列仍然按预期工作吗?

sql database db2
  • 4 4 个回答
  • 32585 Views

4 个回答

  • Voted
  1. Best Answer
    SO User
    2009-06-10T03:30:31+08:002009-06-10T03:30:31+08:00

    蒂姆,我遇到了同样的问题,我需要将身份重新启动到下一个值。我使用的是 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 将用作该列的下一个值。

    • 4
  2. Crowie
    2012-12-19T00:59:01+08:002012-12-19T00:59:01+08:00

    你不能在 DB2 中使用序列号然后使用序列吗?下一个值()?

    在 DB2 中自动生成序列值的链接:http: //www.ibm.com/developerworks/data/library/techarticle/0302fielding/0302fielding.html

    • 2
  3. antih
    2011-11-25T07:24:41+08:002011-11-25T07:24:41+08:00

    你的问题现在可能已经解决了,但是对于所有其他有同样问题的人来说:我可以提供一个解决方案来为所有表获取 max_id +1。唯一的限制是,源列必须是自动增量列 (GENERATED= 'D')。结果集可以通过 clp 或其他查询工具执行。

    SELECT   'alter table ' || rtrim(TABSCHEMA) || '.' || TABNAME || ' alter column ' || COLNAME || ' restart with ' || 
    cast((case when (trim ((replace ( HIGH2KEY, '+' , '' )))) = '' then 0 else integer(trim ((replace ( HIGH2KEY, '+' , '' ))))+2 end) as varchar(20)) 
    || ' ;'
    FROM     SYSCAT.COLUMNS
    WHERE    GENERATED = 'D'
    
    • 1
  4. Arun Srini
    2009-12-16T02:45:43+08:002009-12-16T02:45:43+08:00
    1. 如果您手动导入该列的数据,为什么还要考虑使用自动增量?这种自动增量根本没有被使用,
    2. 在一个类似的应用程序中,我写了一个 SP - a。调用 admin_cmd - 加载选项 b。选择 max(id) - 并将它们与当前时间戳一起加载到日志表中只需查询日志表并使用 bash/windows 脚本进行更新。简单的....
    • 0

相关问题

  • 如何验证 SQLite db3 文件是否有效/一致

  • 使用安全组管理 MS SQL 2005

  • 对于具有许多不同服务的少数服务器来说,一个好的主机名约定?

  • 如何控制 SQL Anywhere 中的临时文件增长?

  • SQL Server 2008 Express - “最佳”备份解决方案?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve