oracle怎么创建字段,创建oracle数据库的命令

oracle 如何才能创建自增字段呢?

1:先创建个Sequence

公司主营业务:成都网站设计、网站制作、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联建站是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联建站推出临漳免费做网站回馈大家。

2:然后创建个触发器, 每新曾一条记录时,Sequence+1 给自增字段赋值

Oracle 给表加多个字段

1、首先打开plsql主面板。

2、选择工具栏中的新建图标,是一个白色的纸张图标。

3、在下拉框中选择sql window。

4、然后会看到新建的sql窗口。

5、在sql窗口中输入查询语句:select 字段名 from 表名。

6、输入完成后,点击左上的执行,是一个圆形锯齿边缘图标。

7、在sql窗口下方,就会弹出你要查询的信息。

在oracle表中怎样创建自增长字段

将表t_uaer的字段ID设置为自增:(用序列sequence的方法来实现)----创建表Create table t_user(

Id number(6),userid varchar2(20),loginpassword varchar2(20),isdisable number(6));----创建序列

create sequence user_seq

increment by 1

start with 1nomaxvaluenominvaluenocache----创建触发器

create or replace trigger tr_user

before insert on t_popedom_user

for each rowbeginselect user_seq.nextval into :new.id from dual;end;----测试insert into t_popedom_user(userid,loginpassword, isdisable)

values('ffll','liudddyujj', 0);

insert into t_popedom_user(userid,loginpassword, isdisable)

values('dddd','zhang', 0)

select * from t_user;

就可以看出结果。

***********************************************************************

对sequence说明:

increment by :用于指定序列增量(默认值:1),如果指定的是正整数,则序列号自动递增,如果指定的是负数,则自动递减。

start with :用于指定序列生成器生成的第一个序列号,当序列号顺序递增时默认值为序列号的最小值 当序列号顺序递减时默认值为序列号的最大值。

Maxvalue:用于指定序列生成器可以生成的组大序列号(必须大于或等于start with,并且必须大于minvalue),默认为nomaxvalue。

Minvalue:用于指定序列生成器可以生成的最小序列号(必须小于或等于starr with,并且必须小于maxvalue),默认值为nominvalue。

Cycle:用于指定在达到序列的最大值或最小值之后是否继续生成序列号,默认为nocycle。

Cache:用于指定在内存中可以预分配的序列号个数(默认值:20)。

在sequence中应注意:

1、 第一次NEXTVAL返回的是初始值;随后的NEXTVAL会自动增加你定义的INCREMENT BY值,然后返回增加后的值。CURRVAL 总是返回当前SEQUENCE的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否则会出错。一次NEXTVAL会增加一次SEQUENCE的值,所以如果你在同一个语句里面使用多个NEXTVAL,其值就是不一样的。

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

关键字:自增 sequence序列 increment start with

如何在ORACLE中创建一个自增字段?

不可以,只能通过创建系列来实现

ORACLE SEQUENCE的简单介绍

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

1、Create Sequence

你首先要有CREATE SEQUENCE或者CREATE ANY SEQUENCE权限,

CREATE SEQUENCE emp_sequence

INCREMENT BY 1 -- 每次加几个

START WITH 1 -- 从1开始计数

NOMAXVALUE -- 不设置最大值

NOCYCLE -- 一直累加,不循环

CACHE 10;

一旦定义了emp_sequence,你就可以用CURRVAL,NEXTVAL

CURRVAL=返回 sequence的当前值

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

比如:

emp_sequence.CURRVAL

emp_sequence.NEXTVAL

可以使用sequence的地方:

- 不包含子查询、snapshot、VIEW的 SELECT 语句

- INSERT语句的子查询中

- NSERT语句的VALUES中

- UPDATE 的 SET中

可以看如下例子:

INSERT INTO emp VALUES

(empseq.nextval, 'LEWIS', 'CLERK',7902, SYSDATE, 1200, NULL, 20);

SELECT empseq.currval FROM DUAL;

但是要注意的是:

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

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

2、Alter Sequence

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

Alter sequence 的例子

ALTER SEQUENCE emp_sequence

INCREMENT BY 10

MAXVALUE 10000

CYCLE -- 到10000后从头开始

NOCACHE ;

影响Sequence的初始化参数:

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

可以很简单的Drop Sequence

DROP SEQUENCE order_seq;

ORACLE 表添加字段求教

create table temp as select * from A;--创建临时表并把原来表A数据放入

drop table A;--删除A表

create table A

(col1 类型,

col2 类型,

col3 类型,

W 类型,

col4 类型,

col5 类型,

col6类型) --建立新A表,类型你按原表来填

insert into A (col1,col2,col3,col4,col5,col6) select * from temp;--插入备份数据

commit;--提交

select * from A--检查一下结果对不对,如果对了的话

drop table temp;--删除临时表


网站标题:oracle怎么创建字段,创建oracle数据库的命令
链接地址:http://csdahua.cn/article/dscjoso.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流