怎么在oracle中写sql语言才能让id自动增加

如题,知道的说说吧... 如题,知道的说说吧 展开
 我来答
psychic0111
2011-01-05 · TA获得超过999个赞
知道小有建树答主
回答量:463
采纳率:100%
帮助的人:222万
展开全部
先为创建SEQUENCE,楼上有介绍
CREATE SEQUENCE SI_EXTERNAL_SEQ --SI_EXTERNAL_SEQ要创建的sequence的名字
INCREMENT BY 1 -- 每次加几个
START WITH 1 -- 从1开始计数
NOMAXVALUE -- 不设置最大值
NOCYCLE -- 一直累加,不循环

然后在插入数据时:insert into 表 values(你的SEQUENCE名.NEXTVAL, 后面省略); --NEXTVAL访问序列的下一个值,CURRVAL是访问当前的值
你可以创建触发器,实现数据插入时序列值的自动生成
create or replace trigger your_seq_tri
before insert on your_table1 for each row
declare
next_id number;
begin
select your_seq.nextval into next_id from dual;
:new.id := next_id;
end;
这样你在插入数据时,不用指定你要自增的列的值
lcqchaochao
推荐于2016-10-12 · 超过37用户采纳过TA的回答
知道小有建树答主
回答量:157
采纳率:0%
帮助的人:110万
展开全部
创建 Sequence 序列
Create Sequence
你首先要有CREATE SEQUENCE或者CREATE ANY SEQUENCE权限,
CREATE SEQUENCE SI_EXTERNAL_SEQ --SI_EXTERNAL_SEQ要创建的sequence的名字
INCREMENT BY 1 -- 每次加几个
START WITH 1 -- 从1开始计数
NOMAXVALUE -- 不设置最大值
NOCYCLE -- 一直累加,不循环
CACHE 10;
也可以在Sequence 那添加
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
Storm_duck
2015-10-31 · TA获得超过1629个赞
知道小有建树答主
回答量:1104
采纳率:82%
帮助的人:451万
展开全部
为ID创建一个SEQuence就好了,在往表中新增数据的时候,用.nextval来完成ID的插入。至于sequence如何创建以及其他使用,可以度娘
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
Joanna_xin
2011-01-05 · 超过17用户采纳过TA的回答
知道答主
回答量:157
采纳率:0%
帮助的人:55.2万
展开全部
学习了.
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式