大橙子网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
oracle sql developer建表的时候id字段的自动递增的设置方法和步骤如下:
成都创新互联主营武宣网站建设的网络公司,主营网站建设方案,重庆APP开发,武宣h5成都小程序开发搭建,武宣网站营销推广欢迎武宣等地区企业咨询
1、首先,打开sql
server数据库,创建一个新表,然后在表中创建id字段并选择int类型,如下图所示,然后进入下一步。
2、其次,完成上述步骤后,选择id字段,然后在下面的列属性中找到标识规范,如下图所示,然后进入下一步。
3、接着,完成上述步骤后,单击标识规范,可以看到默认值为“否”,这表示不递增,如下图所示,然后进入下一步。
4、然后,完成上述步骤后,将标识规范调整为“是”,将“标识增量”设置为1,然后单击保存按钮,如下图所示,然后进入下一步。
5、最后,完成上述步骤后,添加数据时ID将自动递增,如下图所示。这样,问题就解决了。
-----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;
将表t_uaer的字段ID设置为自增:(用序列sequence的方法来实现)----创建表Create table t_user( Id number(6),userid varchar2(20),loginpassword varchar2(20),isdisable number(6));----创建序列 create sequence user_seq increment by 1 start with 1nomaxvaluenominvaluenocache----创建触发器 create or replace trigger tr_user before insert on t_popedom_user for each rowbeginselect user_seq.nextval into :new.id from dual;end;----测试insert into t_popedom_user(userid,loginpassword, isdisable) values('ffll','liudddyujj', 0); insert into t_popedom_user(userid,loginpassword, isdisable) values('dddd','zhang', 0) select * from t_user; 就可以看出结果。 *********************************************************************** 对sequence说明: increment by :用于指定序列增量(默认值:1),如果指定的是正整数,则序列号自动递增,如果指定的是负数,则自动递减。 start with :用于指定序列生成器生成的第一个序列号,当序列号顺序递增时默认值为序列号的最小值 当序列号顺序递减时默认值为序列号的最大值。 Maxvalue:用于指定序列生成器可以生成的组大序列号(必须大于或等于start with,并且必须大于minvalue),默认为nomaxvalue。 Minvalue:用于指定序列生成器可以生成的最小序列号(必须小于或等于starr with,并且必须小于maxvalue),默认值为nominvalue。 Cycle:用于指定在达到序列的最大值或最小值之后是否继续生成序列号,默认为nocycle。 Cache:用于指定在内存中可以预分配的序列号个数(默认值:20)。 在sequence中应注意: 1、 第一次NEXTVAL返回的是初始值;随后的NEXTVAL会自动增加你定义的INCREMENT BY值,然后返回增加后的值。CURRVAL 总是返回当前SEQUENCE的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否则会出错。一次NEXTVAL会增加一次SEQUENCE的值,所以如果你在同一个语句里面使用多个NEXTVAL,其值就是不一样的。 2、 如果指定CACHE值,ORACLE就可以预先在内存里面放置一些sequence,这样存取的快些。cache里面的取完后,oracle自动再取一组到cache。 使用cache或许会跳号, 比如数据库突然不正常down掉(shutdown abort),cache中的sequence就会丢失. 所以可以在create sequence的时候用nocache防止这种情况。 关键字:自增 sequence序列 increment start with
触发器(trigger)或者序列(sequence)来实现。1、序列(sequence) create sequence Sequence_name increment by 1 --表示从1开始计值 start with 1 --每次增长1 nomaxvalue / maxvalue 999999 --有两个可选值,要么无最大值,要么指定最大值; minvalue 1 / nominvaluecycle--表示达到最大值后从头开始,也可以为nocycle;cache 10--指定cache的值。如果指定CACHE值,oracle就可以预先在内存里面放置一些sequence,这样存取的快些。cache里面的取完后,oracle自动再取一组到cache。使用cache或许会跳号, 比如数据库突然不正常down掉(shutdown abort),cache中的sequence就会丢失. 所以可以在create sequence的时候用nocache防止这种情况。 order;--指定排序 序列提供两个方法,NextVal和CurrVal。顾名思义,NextVal为取序列的下一个值,一次NEXTVAL会增加一次sequence的值;CurrVal为取序列的当前值。例如,插入记录时: insert tablename(id) values(sequence_id.nextval);--sequence_id为序列名 但是要注意的是:第一次NEXTVAL返回的是初始值;随后的NEXTVAL会自动增加你定义的INCREMENT BY值,然后返回增加后的值。CURRVAL总是返回当前sequence的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否则会出错。2、触发器(trigger) create or replace trigger trigger_name before insert on your_sid.tablename for each rowbegindeclarei number; cursor cur is select max(id) from your_sid.tablename;BEGINopen cur;FETCH cur INTO i; if i is NULL then :new.id := 0; //可以根据实际需要来定初始值else :new.id := i + 1; //这里以1递增end if;Close cur;END;END;/其中:your_sid为数据库的当前用户SID,tablename为表名,id为列名
呃,简单点的方法:
在表中增加一个列,为自增序列,然后执行:
update
表
set
自增序列=rownum;
这样就把以前的3000多万行都编号了,然后再用sequence做序列;
这样快速,还不会出错。