插入代理键的所有INTO和Sequence.nextval

Rob*_*ert 8 sql oracle plsql

我试图使用INSERT ALL INTO插入40行,我不确定如何插入代理键.这就是我所拥有的

BEGIN
   INSERT ALL 

   INTO  question(question_id)
   VALUES (question_seq.nextval)
END
Run Code Online (Sandbox Code Playgroud)

现在,如果我添加另一个INTO VALUES,那么我会得到一个唯一的约束违规.

BEGIN
   INSERT ALL 

   INTO  question(question_id)
   VALUES (question_seq.nextval)

   INTO  question(question_id)
   VALUES (question_seq.nextval)
END
Run Code Online (Sandbox Code Playgroud)

如何更新每个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())
Run Code Online (Sandbox Code Playgroud)

Jon*_*ler 0

你可以使用这样的东西:

insert into question(question_id)
select question_seq.nextval from
(
    select level from dual connect by level <= 40
);
Run Code Online (Sandbox Code Playgroud)

尽管这不是一种非常方便的格式,特别是如果您想添加其他列。您可能需要创建另一个UNION ALL查询,并通过LEVEL或连接它ROWNUM

我的第一个想法是做这样的事情:

insert into question(question_id)
select question_seq.nextval value from dual
union all
select question_seq.nextval from dual;
Run Code Online (Sandbox Code Playgroud)

但它的产生ORA-02287: sequence number not allowed here,是由于序列值的限制


顺便问一下,你确定你的INSERT ALL工作没有子查询吗?我收到错误,11.2手册ORA-00928: missing SELECT keyword中的图表暗示必须有一个子查询:

在此输入图像描述