现在的位置: 首页 > 综合 > 正文

oracle中如何建立字段自增长

2018年05月09日 ⁄ 综合 ⁄ 共 780字 ⁄ 字号 评论关闭

    oracle中建立字段自增长相对于sql server和mysql还是有点小复杂的,这不为了在oracle中建立字段自增长花了我一天的时间,由于不知道如何建立所以百度,但是百度出来之后复制代码,在其创建触发器的时候老出错啊。直到今天由于偶然的原因才发现错误所在,同时也让我深刻明白:网上那些转来转来的人们啊,建议在转别人的东西之前最好是自己能检验一下啊,不然真坑爹啊!下面开始:

--创建表
CREATE TABLE example(
ID Number(4) NOT NULL PRIMARY KEY,
NAME VARCHAR(25),
PHONE VARCHAR(10),
ADDRESS VARCHAR(50));

--创建序列
CREATE SEQUENCE exam_sequence
INCREMENT BY 1 -- 每次加几个
START WITH 1 -- 从1开始计数
NOMAXVALUE -- 不设置最大值
NOCYCLE -- 一直累加,不循环
NOCACHE -- 不建缓冲区

--创建触发器
CREATE OR REPLACE TRIGGER exam_trg BEFORE
INSERT ON example FOR EACH ROW WHEN (new.id is null)
begin
select emp_sequence.nextval into :new.id from dual;--请注意这里的冒号跟new之间是没有空格的,我从网上复制过来的就是因为中间多了一个空格啊!坑爹啊
end;

--插入数据
INSERT INTO example(Name,phone,address) Values('Riyun','56498543','zhejiang');

 好了,至此在oracle中建立字段自增长已经完毕!

补充oracle中“:”的含义:

:就是个指针,就像c语言中的指针一样
:new 代表 数据改变后的新值,相对应的有 :old  原值
:=   代表 赋值

 

抱歉!评论已关闭.