oracle数据库怎么建sequences作为自增长序列

 我来答
匿名用户
2012-03-19
展开全部
其实Oracle是没有SQL Server 的自增长的列的概念。

我通过这种方式就是为了尽可能模拟。

seq_a 是序列号
insert into t_a (id, value) values(seq_a.nextval,'test'); 这就是Oracle的经典(后者通常)的使用方法。
id当然就是你所谓的自增长列(再次强调,Oracle没有这个概念)
只有通过触发器+sequence,能够实现你所谓自增长列。
micro0369
2012-03-09 · TA获得超过1.2万个赞
知道大有可为答主
回答量:9250
采纳率:85%
帮助的人:3998万
展开全部
create sequences seq_a;

然后在插入数据时,写: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,能够实现你所谓自增长列。
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
陈举超23
推荐于2018-05-18 · TA获得超过1097个赞
知道小有建树答主
回答量:742
采纳率:100%
帮助的人:699万
展开全部
一 创建测试表
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
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
宏之宸
2012-12-19 · TA获得超过228个赞
知道答主
回答量:22
采纳率:0%
帮助的人:9.3万
展开全部
新建-- Create sequence
create sequence
HIBERNATE_SEQUENCE
minvalue 1
maxvalue 999999999
start with 621
increment by 1
cache 10;
这个可以
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
各种计算机资料
2012-03-09 · 超过21用户采纳过TA的回答
知道答主
回答量:223
采纳率:0%
帮助的人:42万
展开全部
create or replace sequences hoho
startwidth 1000
increment 1
nocache
insert into t_a (id, value) values(seq_a.nextval,'test');
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式