oracle数据库怎么建sequences作为自增长序列
5个回答
2012-03-19
展开全部
其实Oracle是没有SQL Server 的自增长的列的概念。
我通过这种方式就是为了尽可能模拟。
seq_a 是序列号
insert into t_a (id, value) values(seq_a.nextval,'test'); 这就是Oracle的经典(后者通常)的使用方法。
id当然就是你所谓的自增长列(再次强调,Oracle没有这个概念)
只有通过触发器+sequence,能够实现你所谓自增长列。
我通过这种方式就是为了尽可能模拟。
seq_a 是序列号
insert into t_a (id, value) values(seq_a.nextval,'test'); 这就是Oracle的经典(后者通常)的使用方法。
id当然就是你所谓的自增长列(再次强调,Oracle没有这个概念)
只有通过触发器+sequence,能够实现你所谓自增长列。
展开全部
create sequences seq_a;
然后在插入数据时,写:seq_a.nextval;
比如 insert into t_a (id, value) values(seq_a.nextval,'test');
也可以增加一个触发器,以实现你所想的自增长列
然后在插入数据时,写:seq_a.nextval;
比如 insert into t_a (id, value) values(seq_a.nextval,'test');
也可以增加一个触发器,以实现你所想的自增长列
追问
谢谢您的回答,但是我还有问题,上面的seq_a、下面的t_a以及里面的参数,id是代表数据库中自增长的列的id吗?参数求您说的在具体点
追答
Oracle是没有SQL Server 的自增长的列的概念。
我通过这种方式就是为了尽可能模拟。
seq_a 是序列号
insert into t_a (id, value) values(seq_a.nextval,'test'); 这就是Oracle的经典(后者通常)的使用方法。
id当然就是你所谓的自增长列(再次强调,Oracle没有这个概念)
只有通过触发器+sequence,能够实现你所谓自增长列。
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
一 创建测试表
SQL> create table t1(id number,sal number);
二 创建序列,初始值1,增长步长1,最大值999
SQL> create sequence seq_t1 increment by 1 start with 1 maxvalue 999;
三 插入数据,引用序列
SQL> insert into t1 values(seq_t1.nextval,10000);
SQL> insert into t1 values(seq_t1.nextval,20000);
SQL> commit;
四 sequences自动增长
SQL> select * from t1;
ID SAL
---------- ----------
2 10000
3 20000
SQL> create table t1(id number,sal number);
二 创建序列,初始值1,增长步长1,最大值999
SQL> create sequence seq_t1 increment by 1 start with 1 maxvalue 999;
三 插入数据,引用序列
SQL> insert into t1 values(seq_t1.nextval,10000);
SQL> insert into t1 values(seq_t1.nextval,20000);
SQL> commit;
四 sequences自动增长
SQL> select * from t1;
ID SAL
---------- ----------
2 10000
3 20000
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
新建-- Create sequence
create sequence
HIBERNATE_SEQUENCE
minvalue 1
maxvalue 999999999
start with 621
increment by 1
cache 10;
这个可以
create sequence
HIBERNATE_SEQUENCE
minvalue 1
maxvalue 999999999
start with 621
increment by 1
cache 10;
这个可以
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
create or replace sequences hoho
startwidth 1000
increment 1
nocache
insert into t_a (id, value) values(seq_a.nextval,'test');
startwidth 1000
increment 1
nocache
insert into t_a (id, value) values(seq_a.nextval,'test');
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询