我正在尝试使用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())
答案 0 :(得分:1)
来自SQL Server后台,我总是在表上创建一个触发器来基本上模拟IDENTITY功能。一旦触发器打开,SK就会像序列一样从序列中自动生成,您不必担心它。
答案 1 :(得分:0)
我不知道这是否是处理此问题的最佳方法,但这是我提出的解决方案:
首先我创建了一个返回值的函数 然后我在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())
答案 2 :(得分:0)
您可以使用以下内容:
insert into question(question_id)
select question_seq.nextval from
(
select level from dual connect by level <= 40
);
虽然它不是一种非常方便的格式,特别是如果您想要添加其他列。您可能需要创建另一个UNION ALL
查询,并通过LEVEL
或ROWNUM
加入。{/ p>
我的第一个想法是做这样的事情:
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: sequence number not allowed here
。
顺便问一下,你确定你的INSERT ALL
没有子查询吗?我收到错误ORA-00928: missing SELECT keyword
,而11.2 manual中的图表意味着必须有一个子查询: