我正在尝试运行以下查询以插入一些节点,这些节点的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。
如果查询仍然可以在一行上运行,我将非常感激,因为我在电子表格中制作这些查询并且仍然希望能够这样做。
答案 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);