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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle数据库,怎么给已有很多数据的表填充自增序列字段相关的知识,希望对你有一定的参考价值。

我的Oracle数据库中有一张表,之前没有设置任何的主键、索引等,目前已经有三千多万行数据,该表有18列,其中只有两列没有值的列。现在在这个表上执行任何查询都已经非常之慢。想为它加个自增序列做主键,用trigger和Sequence做序列的方法会用,但是已有的那三千多万行该怎么快速把这个序列值填充进去呢?
我已经尝试把原表改名重建一个原来名字的表,建好了序列。但是从原来表里把数据导过来的很简单的insert语句执行了两次也没成功,每次大概在一小时后很诡异的报出Oracle发生致命错误而断开连接。
有什么其他快速的方法么?

两个方法:
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')
参考技术A 因你的表没有主键,所以,只能考虑通过通过一个中间表过渡(insert进过渡表时可考虑用Sequence),然后再rename表过来吧 参考技术B 呃,简单点的方法:
在表中增加一个列,为自增序列,然后执行:

update 表 set 自增序列=rownum;

这样就把以前的3000多万行都编号了,然后再用Sequence做序列;
这样快速,还不会出错。本回答被提问者采纳
参考技术C rownum啊
update 摸个字段 = rownum
这个应该可以的哦
参考技术D 表中应该会有序号吧,至少会有 默认的啊,我觉得你可以 查询最后一条数据然后写自增序列,让它从以后的数据开始自增。这样可以吧

给没有id主键的表添加id,并设置为not null 然后填充自增id

买的ip数据库,表上不带id

使用hibernate比较麻烦,所以直接改表

技术分享图片

增加一个字段id,类型int

ALTER TABLE t_ip ADD id int;

 

 设置id不为空设置为主键,自增

 ALTER TABLE `t_ip` CHANGE id id int NOT NULL  AUTO_INCREMENT PRIMARY KEY; 

 运行结果

 技术分享图片

 

以上是关于oracle数据库,怎么给已有很多数据的表填充自增序列字段的主要内容,如果未能解决你的问题,请参考以下文章

mysql 如何给已有表分区

求教在sqlserver2008中的表中怎么添加一列自增的列?

sql server建表时怎么设置ID字段自增

oracle数据库中的表设置主键自增

2017年2月21日 Oracle数据库,怎么设置表中主键的自增

MySQL手动插入数据时怎么让主键自增!