我正在尝试运行以下查询以插入一些节点,这些节点的id会随着节点加载到表中而自动递增.
但是我得到错误,ORA-02287:每当我运行它时,这里不允许序列号.
INSERT INTO V1144Engine.T_NODES VALUES ( (SELECT V1144ENGINE.S_PK_NODES.NEXTVAL FROM dual),1,'Chemistry of Life',SYSDATE,NULL,'CON.3.1',NULL );
我试过跑步
SELECT V1144ENGINE.S_PK_NODES.NEXTVAL from dual
这很好,并返回我想要的数字.
我该如何解决这个问题?我正在运行Oracle 11g.
解决方法
没有必要有内部SELECT.只是
INSERT INTO V1144Engine.T_NODES VALUES(V1144ENGINE.S_PK_NODES.NEXTVAL,null,null);
但是,通常,您希望在INSERT语句中列出要为其提供值的列.这不仅会记录列,以便将来的开发人员不必查找表中列的顺序,它将保护您将来添加到表中的新列.
INSERT INTO V1144Engine.T_NODES( <<list of columns>> ) VALUES(V1144ENGINE.S_PK_NODES.NEXTVAL,null);