Oracle之新手发现:建立类似SQL Server的自增长字段

一直都是用sql server作为开发数据库,最近因为开发新的项目使用oracle数据库,我才开始学习oracle.

学习了一段时间,发现SQL Server和Oracle还是有这很大的差别。首先,我在SQL Server中用得很顺手的自增长字段就在ORACLE中找不到了,朋友说可以用序列可以实现,于是查阅资料,整理出如下示例:

1.建立测试数据表

CREATE TABLE TEST

(

ID NUMBER,

NAME VARCHAR2(20),

PRIMARY KEY(ID)

);

2.创建序列

CREATE SEQUENCE SEQ_TEST;

3.创建触发器

CREATE OR REPLACE TRIGGER AUTOINCREMENT

BEFORE INSERT ON TEST

FOR EACH ROW

WHEN (NEW.ID IS NULL)

BEGIN

SELECT SEQ_TEST.NEXTVAL INTO :NEW.ID FROM DUAL;

END;

/

4.插入数据

INSERT INTO TEST(NAME) VALUES('NAME1');

5.查看插入结果

SELECT * FROM TEST;