oracle数据库,怎么给已有很多数据的表填充自增序列字段

我的Oracle数据库中有一张表,之前没有设置任何的主键、索引等,目前已经有三千多万行数据,该表有18列,其中只有两列没有值的列。现在在这个表上执行任何查询都已经非常之慢... 我的Oracle数据库中有一张表,之前没有设置任何的主键、索引等,目前已经有三千多万行数据,该表有18列,其中只有两列没有值的列。现在在这个表上执行任何查询都已经非常之慢。想为它加个自增序列做主键,用trigger和Sequence做序列的方法会用,但是已有的那三千多万行该怎么快速把这个序列值填充进去呢?
我已经尝试把原表改名重建一个原来名字的表,建好了序列。但是从原来表里把数据导过来的很简单的insert语句执行了两次也没成功,每次大概在一小时后很诡异的报出Oracle发生致命错误而断开连接。
有什么其他快速的方法么?
展开
 我来答
shine戚七七
推荐于2017-09-16 · TA获得超过4.7万个赞
知道大有可为答主
回答量:2万
采纳率:75%
帮助的人:2588万
展开全部
两个方法:
1,重新创建一个表,然后创建一个序列,把老数据导入新表,删除老表,修改新表名字为老表
2,直接在原来表上增加一个字段,创建一个序列,通过更新的方式修改老数据的这个字段。

具体操作主要是2点,首先是创建一个序列名sequence;
然后是,insert语句的时候:将自增的字段的位置,写成序列名.nextval。
从创建表开始,然后创建sequence,到insert语句
1.首先创建表
CREATE TABLE "FLOWCAL"."T_USERINFO"
( "C_ID" NUMBER(*,0),
"C_USER" VARCHAR2(20 BYTE),
"C_PASSWORD" VARCHAR2(20 BYTE),
"C_ROLE" VARCHAR2(20 BYTE),
"C_COMMENT1" VARCHAR2(20 BYTE),
"C_COMMENT2" VARCHAR2(20 BYTE)
)
现在想让C_ID自增一。

2.首先创建一个oracle的sequence,sql语句如下:
create sequence 序列名
increment by 1
start with 1
maxvalue 999999999
cycle;
建立一个最小为1,最大为999999999的一个序列号会自动循环的序列

下面的sequence,如下:
CREATE SEQUENCE "FLOWCAL"."SEQ_USERINFO"
MINVALUE 0
MAXVALUE 9999999999999999999999999999
INCREMENT BY 1
START WITH 24
CACHE 20
ORDER
CYCLE ;

3.通过序列名.nextval实现插入时,字段的自增一
当向表中插入数据时,SQL语句写法如下:
SQL> insert into 表名 values(,列1值,列2值,....);
"序列名"可以替换为自己需要的名字.

下面insert语句:
insert into T_USERINFO values(SEQ_USERINFO.NEXTVAL,'111','11','11','11','11')
TableDI
2024-07-18 广告
作为上海悉息信息科技有限公司的员工,我们在处理Excel表格数据比对时,通常会使用Excel的高级功能或专门的比对工具。首先,确保两个表格的数据结构相似,然后可以使用“条件格式”中的“突出显示单元格规则”下的“重复值”功能,来高亮显示两个表... 点击进入详情页
本回答由TableDI提供
vinson_shen
2010-07-02 · TA获得超过2503个赞
知道小有建树答主
回答量:960
采纳率:100%
帮助的人:0
展开全部
因你的表没有主键,所以,只能考虑通过通过一个中间表过渡(insert进过渡表时可考虑用Sequence),然后再rename表过来吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
BaiYansong
推荐于2017-10-11 · TA获得超过764个赞
知道小有建树答主
回答量:339
采纳率:0%
帮助的人:388万
展开全部
呃,简单点的方法:
在表中增加一个列,为自增序列,然后执行:

update 表 set 自增序列=rownum;

这样就把以前的3000多万行都编号了,然后再用Sequence做序列;
这样快速,还不会出错。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
biqidaoer
2010-07-02 · TA获得超过325个赞
知道答主
回答量:234
采纳率:0%
帮助的人:101万
展开全部
rownum啊
update 摸个字段 = rownum
这个应该可以的哦
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
RegistIn
2010-07-02 · TA获得超过105个赞
知道答主
回答量:129
采纳率:0%
帮助的人:60万
展开全部
表中应该会有序号吧,至少会有 默认的啊,我觉得你可以 查询最后一条数据然后写自增序列,让它从以后的数据开始自增。这样可以吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式