【问题标题】:Sequence error in sql. Sequence number not allowed heresql中的序列错误。此处不允许使用序列号
【发布时间】:2012-06-29 18:52:50
【问题描述】:

我正在尝试运行以下查询以插入多个具有 id 的节点,这些节点会随着节点加载到表中而自动递增。

但是,每当我运行它时,我都会收到错误 ORA-02287: sequence number not allowed here

INSERT INTO V1144Engine.T_NODES VALUES
  (
    (SELECT V1144ENGINE.S_PK_NODES.NEXTVAL FROM dual),
    1,
    'Chemistry of Life',
    0,1,
    SYSDATE,
    NULL,
    'CON.3.1',
    NULL
  );

我试过跑步

SELECT V1144ENGINE.S_PK_NODES.NEXTVAL from dual

这工作正常并返回我想要的数字。

我该如何解决这个问题?我在 Oracle 11g 上运行。

如果查询仍然可以在一行上运行,我将不胜感激,因为我正在电子表格中进行这些操作并且希望仍然能够这样做。

【问题讨论】:

    标签: sql oracle oracle11g


    【解决方案1】:

    没有必要有内部SELECT。简单的

    INSERT INTO V1144Engine.T_NODES 
      VALUES(V1144ENGINE.S_PK_NODES.NEXTVAL,
             1,
             'Chemistry of Life',
             0,
             1,
             SYSDATE,
             null,
             'CON.3.1',
             null);
    

    不过,一般来说,您希望列出您在INSERT 语句中为其提供值的列。这不仅记录了列,以便未来的开发人员不必在表中查找列的顺序,而且在将来将新列添加到表中时,它可以保护您。

    INSERT INTO V1144Engine.T_NODES( <<list of columns>> ) 
      VALUES(V1144ENGINE.S_PK_NODES.NEXTVAL,
             1,
             'Chemistry of Life',
             0,
             1,
             SYSDATE,
             null,
             'CON.3.1',
             null);
    

    【讨论】:

    猜你喜欢
    • 2018-09-28
    • 2020-03-31
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-11-07
    • 1970-01-01
    相关资源
    最近更新 更多