189 8069 5689

oracle怎么给表加列 oracle添加列的语句

如何在oracle表中添加一列数据 ,并且自动增长?

oracle中没有自动增长,只有序列号

创新互联公司-专业网站定制、快速模板网站建设、高性价比掇刀网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式掇刀网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖掇刀地区。费用合理售后完善,十载实体公司更值得信赖。

添加一条记录和sqlserver一样

语法:insert into table(列,列,列) values(value,value,value);

如果有个自动增长列

可以用这种方法,首先创建一个序列号SEQ_Test

然后insert into table(ID,列,列) values(SEQ_Test.nextval,value,value);

oracle 给表添加整数列

有固定的语法格式可以添加。

语法:alter table 表名 add 列名 列格式 [null/not null]。

注意:添加非空列时,要保证表中没有数据。

如何给oracle中的表建一个序列

在oracle中sequence就是所谓的序列号,每次取的时候它会自动增加,一般用在需要按序列号排序的地方。

1、createsequence

你首先要有createsequence或者createanysequence权限,

createsequenceemp_sequence

incrementby1--每次加几个

startwith1--从1开始计数

nomaxvalue--不设置最大值

nocycle--一直累加,不循环

cache10;

一旦定义了emp_sequence,你就可以用currval,nextval

currval=返回sequence的当前值

nextval=增加sequence的值,然后返回sequence值

比如:

emp_sequence.currval

emp_sequence.nextval

可以使用sequence的地方:

-不包含子查询、snapshot、view的select语句

-insert语句的子查询中

-nsert语句的values中

-update的set中

可以看如下例子:

insertintoempvalues

(empseq.nextval,'lewis','clerk',7902,sysdate,1200,null,20);

selectempseq.currvalfromdual;

但是要注意的是:

-第一次nextval返回的是初始值;随后的nextval会自动增加你定义的incrementby值,然后返回增加后的值。currval总是返回当前sequence的值,但是在第一次nextval初始化之后才能使用currval,否则会出错。一次nextval会增加一次sequence的值,所以如果你在同一个语句里面使用多个nextval,其值就是不一样的。明白?

-如果指定cache值,oracle就可以预先在内存里面放置一些sequence,这样存取的快些。cache里面的取完后,oracle自动再取一组到cache。使用cache或许会跳号,比如数据库突然不正常down掉(shutdownabort),cache中的sequence就会丢失.所以可以在createsequence的时候用nocache防止这种情况。

2、altersequence

你或者是该sequence的owner,或者有alteranysequence权限才能改动sequence.可以alter除start至以外的所有sequence参数.如果想要改变start值,必须dropsequence再re-create.

altersequence的例子

altersequenceemp_sequence

incrementby10

maxvalue10000

cycle--到10000后从头开始

nocache;

影响sequence的初始化参数:

sequence_cache_entries=设置能同时被cache的sequence数目。

可以很简单的dropsequence

dropsequenceorder_seq;

oracle怎么用命令向建好的表中插入一列并使它成为第一列?请说详细点,最好举例说明。

分为两步来实现,首先插入数据,假设表T,有字段col1,col2,col3,需要向前200行的col2插入行数+1的值,并将col2变为第一列,

插入数据有两种方法:

1》直接update即:UPDATE T SET T.COL2 = ROWNUM + 1 WHERE ROWNUM =200;

2》写一个存储过程

CREATE OR REPLACE PROCEDURE INS IS

BEGIN

FOR I IN 1 .. 200 LOOP

INSERT INTO T (COL2) VALUES (I);

END LOOP;

COMMIT;

END;

编译并运行该过程,插入列即完成。

下面将COL2列调整为第一列:

方法一:借用临时表,建temp表与t表的表结构、数据完全一致,重建t表,调整字段顺序,再将temp表的数据导回来,即

CREATE TABLE TEMP AS SELECT * FROM T;

CREATE TABLE T(

COL2 TYPE,

COL1 TYPE,

COL3 TYPE

);

INSERT INTO T

SELECT COL2,COL1,COL3 FROM TEMP;

COMMIT;

DROP TABLE TEMP;

此方法需要足够的空间、回滚段和时间消耗

方法2:利用数据库表对象更新字段的序列号

在当前表用户下使用下面命令查询T对象的编号:

select OBJECT_name,object_id from all_objects where object_name='T';(注意一定要大写)

SQL /

OBJECT_NAME OBJECT_ID

------------------------------ ----------

T 50555

切换到sys帐号下

select obj#,col#,name from col$ where obj#=50555;

OBJ# COL# NAME

---------- ---------- ----------------------------

50555 1 COL1

50555 2 COL2

50555 3 COL3

Elapsed: 00:00:00.03

下面可以通过修改这个系统表来实现修改列名与顺序,注意,COL#就是列的顺序。

UPDATE COL$ SET COL#=2 WHERE OBJ#=50555 and name='COL1';

UPDATE COL$ SET COL#=1 WHERE OBJ#=50555 and name='COL2';

再次查询

select obj#,col#,name from col$ where obj#=50555;

OBJ# COL# NAME

---------- ---------- ------------------------------

50555 1 COL2

50555 2 COL1

50555 2 COL3

提交修改commit ;

重启服务

SQL SHUTDOWN IMMEDIATE

SQLSTARTUP

重新登录表用户下,查询SELECT * FROM T;

COL2 COL1 COL3

至此列顺序调整成功


本文标题:oracle怎么给表加列 oracle添加列的语句
当前链接:http://cdxtjz.cn/article/hhdcsh.html

其他资讯