多个用户同时向oracle中一个表插入数据,经常出现主键冲突,主键是通过sequence获得的

怎么防止主键冲突,使得所有数据都能正常保存进去?
2024-12-28 01:21:25
推荐回答(4个)
回答1:

这个是不可能的。Sequense是严格的序列号,除非被循环了。同时并发的要求SEQ,数据库的锁机制会将用户排队,保证获得的序列是不一样的数字。
检查你的程序吧,程序的主键必然不是严格通过SEQ获得的

回答2:

用sequence是不会出现并发问题的,除非是你人为的把序列的得到和插入数据分成两步了。

回答3:

insert into 表名(序列名字.nextval,列值1,列值2..);

回答4:

插值时,不要插入主键啊