在plsql developer中如何给表设一个自增主键

yzy401 2010-02-01 03:10:34
请教两个问题:
一、在plsql developer中如何给表设一个自增主键?
二、对于设置了自增主键的表,写存储过程时有影响否?
...全文
6374 6 打赏 收藏 举报
写回复
6 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
chenliaoliu 2012-04-26
  • 打赏
  • 举报
回复
SELECT seq_t_client_id.nextval INTO :new.id FROM dual;
为什么这条语句会返回多行值,换成CURRVAL也是喔,这样就不能成功插入了啊
徐小路 2010-02-01
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 crazylaa 的回复:]
SQL code
oracle没有ORACLE自增字段这样的功能,但是通过触发器(trigger)和序列(sequence)可以实现。createtable t_client (idnumber(4)primarykey,
pidnumber(4)notnull,
namevarchar2(30)notnull,
client_idvarchar2(10),
client_levelchar(3)?-
[/Quote]

JF顶一下!
gelyon 2010-02-01
  • 打赏
  • 举报
回复
楼上两位已经给了很满意的答案了
crazylaa 2010-02-01
  • 打赏
  • 举报
回复

oracle没有ORACLE自增字段这样的功能,但是通过触发器(trigger)和序列(sequence)可以实现。
create table t_client (id number(4) primary key,
pid number(4) not null,
name varchar2(30) not null,
client_id varchar2(10),
client_level char(3),
bank_acct_no varchar2(30),
contact_tel varchar2(30),
address varchar2(30),
zip_code varchar2(10),
is_leaf char(1) default 'y' check (is_leaf in('y','n')),
is_client char(1) default 'n' check (is_client in('y','n')
));

假设关键字段为id,建一个序列,代码为:
create sequence seq_t_client_id
minvalue 1
maxvalue 99999999
start with 1
increment by 1
nocache
order;
建解发器代码为:
CREATE OR REPLACE TRIGGER trg_t_client_id
BEFORE INSERT ON t_client
FOR EACH ROW
BEGIN
SELECT seq_t_client_id.nextval INTO :new.id FROM dual;
END;
/
Dave 2010-02-01
  • 打赏
  • 举报
回复


Oracle 没有自增的概念,需要用触发器加sequence来实现


ORACLE SEQUENCE 介绍
http://blog.csdn.net/tianlesoftware/archive/2009/10/30/4745039.aspx



------------------------------------------------------------------------------
Blog: http://blog.csdn.net/tianlesoftware
网上资源: http://tianlesoftware.download.csdn.net
相关视频:http://blog.csdn.net/tianlesoftware/archive/2009/11/27/4886500.aspx
Q Q 群:62697716
相关推荐
发帖
Oracle 高级技术

3471

社区成员

Oracle 高级技术相关讨论专区
社区管理员
  • 高级技术社区
加入社区
帖子事件
创建了帖子
2010-02-01 03:10
社区公告
暂无公告