sql中的序列错误。此处不允许序列号

时间:2012-06-29 18:52:50

标签: sql oracle oracle11g

我正在尝试运行以下查询以插入一些节点,这些节点的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。

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

1 个答案:

答案 0 :(得分:22)

没有必要拥有内部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);