oracle两个表使用同一个sequence生成主键,有什么后果? 5

 我来答
loveyurui
2014-07-29 · TA获得超过6555个赞
知道大有可为答主
回答量:2892
采纳率:33%
帮助的人:967万
展开全部
建议一个序列就用于一个表的主键。
如果两个表共用,也没什么严重后果。一样能保证主键唯一非空,就是两个表各自的主键数据不连续而已。
追问
如果数据量比较大的话呢?而且最开始两个表分别用各自的序列。现在一个数据少的表想修改成使用数据量大的表对应的序列,怎么操作比较好呢?有啥后果吗?
追答
也可以。没什么后果。
就是这个操作过程麻烦一点。
表名 序列名
A seq_a 数据量大的表
B seq_b 数据量小的表
现在将B修改成使用A表对应的序列,即seq_a。分为两种情况:
1 B表原来主键id不变。 新插入的记录使用seq_a。 insert into b vlaues(seq_a.nextval(),.....);
2 如果要求B原来的记录的主键也变化的话,就麻烦一点。
(1)首先保证B表不插入新的记录
(2) 将B表记录转移一下,转移的同时修改主键
insert into c select seq_a.nextval(),...... from b;
joychen_
2014-07-29 · TA获得超过1747个赞
知道大有可为答主
回答量:1617
采纳率:100%
帮助的人:1807万
展开全部
就是不连续啊,序列每次加1的话,A表取到1,B表取2,A表再取就是3
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式