我正在尝试使用INSERT ALL INTO插入40行,我不确定如何插入代理键.这就是我所拥有的
BEGIN INSERT ALL INTO question(question_id) VALUES (question_seq.nextval) END
现在如果我添加另一个INTO VALUES,那么我会得到一个唯一的约束违规.
BEGIN INSERT ALL INTO question(question_id) VALUES (question_seq.nextval) INTO question(question_id) VALUES (question_seq.nextval) END
如何更新每个INTO VALUES的序列nextval值,以便我可以避免唯一约束违规?我假设nextval会自动更新.
更新:我不知道这是否是处理此问题的最佳方法,但这是我提出的解决方案:
首先,我创建了一个返回值的函数
然后我在VALUES子句的id字段中调用了该函数
create or replace FUNCTION GET_QUESTION_ID RETURN NUMBER AS num NUMBER; BEGIN SELECT UHCL_QUESTIONS_SEQ.nextval INTO num FROM dual; return num; END GET_QUESTION_ID; INSERT ALL INTO question(question_id) VALUES (GET_QUESTION_ID()) INTO question(question_id) VALUES (GET_QUESTION_ID())
解决方法
你可以使用这样的东西:
insert into question(question_id) select question_seq.nextval from ( select level from dual connect by level <= 40 );
虽然它不是一种非常方便的格式,特别是如果您想要添加其他列.您可能需要创建另一个UNION ALL查询,并通过LEVEL或ROWNUM加入它.
我的第一个想法是做这样的事情:
insert into question(question_id) select question_seq.nextval value from dual union all select question_seq.nextval from dual;
但由于restrictions on sequence values,它会生成ORA-02287:此处不允许的序列号.
顺便说一句,你确定你的INSERT ALL在没有子查询的情况下工作吗?我收到错误ORA-00928:缺少SELECT关键字,而11.2 manual中的图表意味着必须有一个子查询: