oracle怎么实现自增 oracle怎么设置自增-成都快上网建站

oracle怎么实现自增 oracle怎么设置自增

oracle自增长怎么做?

首先,Oracle中没有像MySQL那样的id自增长功能

目前成都创新互联公司已为成百上千的企业提供了网站建设、域名、虚拟空间、网站托管运营、企业网站设计、青州网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。

如果要用Oracle这么做的话首先要先建一个表,如:

CREATE

TABLE

test(

ID

Number(4)

NOT

NULL

PRIMARY

KEY,

NAME

VARCHAR(25),

PHONE

VARCHAR(10),

ADDRESS

VARCHAR(50));

然后,你需要一个自定义的sequence:

CREATE

SEQUENCE

emp_sequence

INCREMENT

BY

1

--

每次加几个

START

WITH

1

--

从1开始计数

NOMAXVALUE

--

不设置最大值

NOCYCLE

--

一直累加,不循环

NOCACHE

--

不建缓冲区

你只有了表和序列还不够,还需要一个触发器来执行它:

CREATE

TRIGGER

"触发器名称"

BEFORE

INSERT

ON

example

FOR

EACH

ROW

WHEN

(new.id

is

null)

begin

select

emp_sequence.nextval

into:

new.id

from

dual;

end;

这时你再向test表中插数据就可以不用管id了

在oracle 怎样设置自动递增的的字段?

关于主键:在建表时指定primary key字句即可:

create table test(

id  number(6) primary key,

name varchar2(30)

);

如果是对于已经建好的表,想增加主键约束,则类似语法:

alter table test add constraint pk_id primary key(id);  

其中add constraint 和 primary key是关键字,pk_id是主键名称,自定义的额,只要不重复即可。

也可以自动一些,对表的插入操作,建立一个触发器,每当有数据插入时,触发器自动修改id值为序列的新值,这样就完全实现自增id功能了。不过其实也没有这个必要。因为触发器如果建多了,有时会比较混乱,不易管理。

oracle中如何实现某一字段自增

-----oracle 指定字段 自增 ,1.要先创建一个序列 2. 之后创建一个触发器

--- 序列 (序列与触发器实现t_sys_organize表中F_ID字段的自动增长)

create sequence t_sys_organize_F_ID_SEQUENCE

minvalue 100000

maxvalue 99999999

start with 100000

increment by 1

nocache;

--触发器 (序列与触发器实现t_sys_organize表中F_ID字段的自动增长)

CREATE OR REPLACE TRIGGER t_sys_organize_F_ID_TRIGGER BEFORE INSERT ON t_sys_organize FOR EACH ROW WHEN(NEW.F_ID IS NULL)

BEGIN

SELECT t_sys_organize_F_ID_SEQUENCE.NEXTVAL INTO:NEW.F_ID FROM dual;

END;


分享名称:oracle怎么实现自增 oracle怎么设置自增
当前地址:http://kswjz.com/article/hichdg.html
扫二维码与项目经理沟通

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

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