ORACLE里设置列自动增长
2008-03-24 14:32
357 查看
在oracle里创建列自动增长步骤如下:
1 首先创建一个表,例如:
CREATE TABLE "DEPARTMENT"
( "DEPARTMENT_ID" NUMBER,
"DEPARTMENT_NAME" VARCHAR2(30) NOT NULL ENABLE,
"MANAGER_ID" NUMBER(6,0),
"LOCATION_ID" NUMBER(4,0),
PRIMARY KEY ("DEPARTMENT_ID") ENABLE
)
/
2 为DEPARTMENT_ID列创建序列:
CREATE SEQUENCE "DEPARTMENT_SEQ" MINVALUE 1 MAXVALUE 9999 INCREMENT BY 1 START WITH 1 NOCACHE NOORDER NOCYCLE
3 为该表创建触发器:
CREATE OR REPLACE TRIGGER "INSERT_DEPARTMENT"
BEFORE
insert on "DEPARTMENT"
for each row
begin
select "DEPARTMENT_SEQ".nextval into :NEW.DEPARTMENT_ID from dual;
end;
/
ALTER TRIGGER "INSERT_DEPARTMENT" ENABLE
/
4 完毕,接下来如果你需要往表格里插入数据,则DEPARTMENT_ID就可以自动增长了。列最小值为1,最大值为9999,而且增加基数为1,这几个值你都可以根据自己的需要进行修改。
5 Oracle里另一种实现自动增长的方法如下(仍然以上面建的表为例):
首先创建序列:
drop sequence department_seq;
create sequence department_seq
increment by 1
start with 1
maxvalue 9999999999
nocache;
接下来直接就可以写插入语句了,具体的SQL如下:
insert into department values(department_seq.nextval,'研发部',8,10);
由此可见,完成一个功能的方法是多种多样的,坦白说,我也不知道这两种方法孰好孰坏,但我更加偏向于使用第一中方法。
1 首先创建一个表,例如:
CREATE TABLE "DEPARTMENT"
( "DEPARTMENT_ID" NUMBER,
"DEPARTMENT_NAME" VARCHAR2(30) NOT NULL ENABLE,
"MANAGER_ID" NUMBER(6,0),
"LOCATION_ID" NUMBER(4,0),
PRIMARY KEY ("DEPARTMENT_ID") ENABLE
)
/
2 为DEPARTMENT_ID列创建序列:
CREATE SEQUENCE "DEPARTMENT_SEQ" MINVALUE 1 MAXVALUE 9999 INCREMENT BY 1 START WITH 1 NOCACHE NOORDER NOCYCLE
3 为该表创建触发器:
CREATE OR REPLACE TRIGGER "INSERT_DEPARTMENT"
BEFORE
insert on "DEPARTMENT"
for each row
begin
select "DEPARTMENT_SEQ".nextval into :NEW.DEPARTMENT_ID from dual;
end;
/
ALTER TRIGGER "INSERT_DEPARTMENT" ENABLE
/
4 完毕,接下来如果你需要往表格里插入数据,则DEPARTMENT_ID就可以自动增长了。列最小值为1,最大值为9999,而且增加基数为1,这几个值你都可以根据自己的需要进行修改。
5 Oracle里另一种实现自动增长的方法如下(仍然以上面建的表为例):
首先创建序列:
drop sequence department_seq;
create sequence department_seq
increment by 1
start with 1
maxvalue 9999999999
nocache;
接下来直接就可以写插入语句了,具体的SQL如下:
insert into department values(department_seq.nextval,'研发部',8,10);
由此可见,完成一个功能的方法是多种多样的,坦白说,我也不知道这两种方法孰好孰坏,但我更加偏向于使用第一中方法。
相关文章推荐
- Oracle创建表设置自动增长列范例
- 如何在oracle中设置字段自动增长
- Mysql,SqlServer,Oracle主键自动增长的设置
- Mysql,SqlServer,Oracle主键自动增长的设置
- oracle设置自动增长序列
- 如何在oracle中设置字段自动增长
- Mysql,SqlServer,Oracle主键自动增长的设置
- Oracle中为表设置自动增长的标识列
- Mysql,SqlServer,Oracle主键自动增长的设置
- oracle主键自动增长的设置
- Oracle 主键自动增长设置
- oracle建表并设置ID为自动增长
- oracle:设置自动增长列
- Mysql,SqlServer,Oracle主键自动增长的设置
- Oracle设置自动增长
- Oracle中为表设置自动增长的标识列
- 给oracle设置自动增长列
- Oracle, Mysql,SqlServer主键自动增长的设置
- Mysql,SqlServer,Oracle主键自动增长的设置
- Mysql,SqlServer,Oracle主键自动增长的设置