加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sql – 为代理键插入所有INTO和Sequence.nextval

发布时间:2020-12-12 06:38:04 所属栏目:MsSql教程 来源:网络整理
导读:我正在尝试使用INSERT ALL INTO插入40行,我不确定如何插入代理键.这就是我所拥有的 BEGIN INSERT ALL INTO question(question_id) VALUES (question_seq.nextval)END 现在如果我添加另一个INTO VALUES,那么我会得到一个唯一的约束违规. BEGIN INSERT ALL INTO
我正在尝试使用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中的图表意味着必须有一个子查询:

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读