重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
-----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中没有自动增长,只有序列号\x0d\x0a添加一条记录和sqlserver一样\x0d\x0a语法:insert into table(列,列,列) values(value,value,value); \x0d\x0a\x0d\x0a如果有个自动增长列\x0d\x0a可以用这种方法,首先创建一个序列号SEQ_Test\x0d\x0a然后insert into table(ID,列,列) values(SEQ_Test.nextval,value,value);
首先,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了