资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

oracle如何实现递增,oracle字段递增

ORACLE主键自增长(序列+触发器)

以前用的mysql,是有自动递增这个属性的,现在用的orlace,需要建序列来实现递增,这里记录一下:

成都创新互联公司从2013年创立,是专业互联网技术服务公司,拥有项目网站制作、做网站网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元崇川做网站,已为上家服务,为崇川各地企业和个人服务,联系电话:18980820575

一、先建一张表(PROJECT_LOGS)

二、表建好了,我们来建一下序列,我用的是sqldeveloper界面来建:

其实到了这里就实现了递增,只是写sql时要传入id(SEQ_PROJECT_LOGS.Nextval);

三、创建触发器:

在oracle 怎样设置自动递增的的字段,也就是设置自动递增的ID 主键

Oracle中没有已定义好的自动编号列,需要自己创建,下面总结Oracle 10g中自动编号列的创建方法:

1. 首先需要给要添加自动编号列的表创建索引,被索引的列就是后面要实现的自动编号列,这样的列往往是名为“ID”的列。创建索引可以通过OEM创建,也可以在SQL*Plus或PL/SQL中通过SQL语句创建。以方案LY中的表HARD为例,给其hard_id列创建索引的SQL语句为:

CREATE UNIQUE INDEX LY.HARD ON LY.HARD(hard_id);

2. 然后需要创建一个最小值为1,最大值不限,递增值为1的序列。序列的创建同样可以通过OEM或直接输入SQL语句创建。创建序列的SQL语句为:

drop sequence HARD_SEQ;

create sequence HARD_SEQ

minvalue 1

maxvalue 999999999999999999999999999

start with 21

increment by 1

cache 20

order;

3.最后为表LY.HARD创建触发器,以实现在每次插入行时,hard_id列自动递增编号。触发器的创建同样可以方便的由OEM创建,也可以用SQL语句创建。下面为创建触发器的SQL语句:

CREATE OR REPLACE TRIGGER "HARD_ID_TRIGGER" BEFORE

INSERT ON "LY"."HARD" FOR EACH ROW

declare

next_checkup_no number;

begin

select hard_seq.nextval

into next_checkup_no

from dual;

:NEW.hard_id := next_checkup_no;

end;

需要注意的是,在用OEM创建触发器时,有可能出现“Failed to commit: 索引中丢失 IN 或 OUT 参数:: 1”的错误提示,在网上查阅了一些资料,认为这可能是Oracle中的一个BUG,所以建议使用SQL语句创建触发器。

Navicat for Oracle中如何设置某一字段为自动递增?

可以通过设置序列(sequence)的形式实现:\x0d\x0a第一步:创建sequence,让 INCREMENT BY增长速度为1,START WITH(开始值为 1)。创建sequence语句如下:\x0d\x0aCREATE SEQUENCE SEQ_NO\x0d\x0a MINVALUE 1 --最小值\x0d\x0a NOMAXvalue -----没有最大值\x0d\x0a INCREMENT BY 1 ----每次递增1\x0d\x0a START WITH 1 -----开始值为1\x0d\x0a NOCACHE ----------不缓存\x0d\x0a NOCYCLE ; ---------不循环\x0d\x0a第二步:每次插入的时候直接\x0d\x0a”insert into tablename(ID) values(SEQ_NO.nextVal)“即可。


分享名称:oracle如何实现递增,oracle字段递增
文章分享:http://www.cdkjz.cn/article/hdehgo.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

大客户专线   成都:13518219792   座机:028-86922220