9

我正在尝试运行以下查询来插入许多具有 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 上运行。

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

4

1 回答 1

23

没有必要有内在的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);
于 2012-06-29T19:02:15.740 回答