请教两个问题:
一、在plsql developer中如何给表设一个自增主键?
二、对于设置了自增主键的表,写存储过程时有影响否?
一、在plsql developer中如何给表设一个自增主键?
二、对于设置了自增主键的表,写存储过程时有影响否?
解决方案 »
- OEM中关闭数据库遇到的问题
- 帮忙解释下这个sql,多谢!
- 物化视图的刷新,出现权限不足
- 新年快乐!请教这样的SQL要怎么写?
- 有关C# 中连接ORACLE数据库的问题?? 技术达人请进!
- 想通过Oracle Enterprise Manager Console(我是Oracle9i) 实现数据的导入/导出,并已建立了资料库,可是我登录到OMS后,却。。。
- group by的结果可以和别的搜索结果联起来吗?
- 安装完ORCLE及建立数据库后为啥子没有MISDATA目录?没有创建表空间成功吗?(初学者)
- 各位大虾:我是菜鸟,请问???
- ORACLE应用运行太慢!!!求助找原因
- @@@@@@@@@咨询针对Oracle JVM的wrapper
- 求一查询oracle数据库死锁的SQL语句
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没有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;
/
http://school.itzcn.com/special-spid-35.html
上面讲解的比较详细,
希望对楼主有所帮助。
为什么这条语句会返回多行值,换成CURRVAL也是喔,这样就不能成功插入了啊