当前位置:首页 » 存储配置 » oracle存储过程自增

oracle存储过程自增

发布时间: 2022-04-28 20:20:26

㈠ Oracle中触发器实现序列自增

Oracle8i中存储过程的类型

Oracle8i支持的存储过程类型有几种?Oracle8i 支持四种不同类型的存储过程用PL/sql或Java,都可以实现全部四种类型的存储过程。这四种存储过程类型是:

存储过程顶级存储过程允许客户用任意商业逻辑扩展SQL。客户用名称调用存储过程,可以在SQL、PL/SQL包、以及“顶级”位置上调用存储过程。

存储函数存储函数实质上与存储过程相同,不同之处在于存储函数向调用者返回值。可以用名称调用存储函数,也可以在SQL、PL/SQL包、以及“顶级”位置上调用存储函数。

数据库触发器:触发器是与特定的表和视图关联的商业规则,修改对表或视图时,SQL自动调用触发器。Oracle8i 提供了几种类型的触发器:在SQLDML语句执行之前或之后激发的触发器;在每一行更新之前或之后激发的触发器;事件触发器(例如:登录、退出、DDL语句、数据库启动或关闭等的触发器);替代(instead-of)触发器。所有这些触发器类型,都可以用PL/SQL或Java编写。

对象类型方法 Oracle8 ™ 发行版8.0和Oracle8i提供了用SQL定义复合数据类型的能力。这些对象类型的方法,可以用Java实现,也可用PL/SQL实现。例如,可以用SQL定义一个订单对象类型purchase_order_t,如下所示:

㈡ 在oracle存储过程中建立序列

序列主要是用来生成固定的编号的,如:每次递增一即可。
create sequence SEQ_ID
minvalue 1
maxvalue 99999999
start with 1
increment by 1
cache 30
cycle;
之后执行:
insert into tab (auto_id) values (SEQ_ID.Nextval);
备注:sequence 是一个自增长的序列,每次调用nextval的时候会自动增加,可以定义起始值,最大值,增量,cycle是表示循环,即到最大值后从起始值重新开始。 每次执行都是会自增的。

㈢ oracle是怎么实现表的自增

用触发器trigger的功能来实现它: 1、首先建立一个创建自增字段的存储过程create or replace procere pro_create_seq_col
(tablename varchar2,columnname varchar2)
as
strsql varchar2(1000);
begin
strsql := 'create sequence seq_'||tablename||' minvalue 1 maxvalue 999999999999999999 start with 1 increment by 1 nocache';
execute immediate strsql;
strsql := 'create or replace trigger trg_'||tablename||' before insert on '||tablename||' for each row begin select seq_'||tablename||'.nextval into :new.'||columnname||' from al; end;';
execute immediate strsql;
end;
/
2、Oracle中执行动态SQL时要显示授权(即使该用户拥有该相关权限)GRANT CREATE ANY SEQUENCE TO UserName;
GRANT CREATE ANY TRIGGER TO UserName;
3、重新Compile存储过程pro_create_seq_col; 4、搞定,下面我们就可以用这个存储过程建立自增自段了。 5、调用存储过程建立自增字段(提示: 第一个参数是表名,第二个参数为自增字段的名字)exec pro_create_seq_col('sb_zsxx','zsxh');
exec pro_create_seq_col('sb_sbxx','sbxh');
exec pro_create_seq_col('sb_jkx','pzxh');
exec pro_create_seq_col('sdspfp','sysfpid');

㈣ 如何让oracle自动增长的序列到一定时间自动重新开始增长

做一个存储过程,drop此序列,重建序列

做一个Oracle Job,按照你指定时间调度。

㈤ oracle怎么实现id自增和设置主键啊

可以使用序列实现id自增,主键的语法为primary key。

当一个序列第一次被查询调用时,它将返回一个预定值。在随后的每次查询中,序列将产生一个按指定的增量增长的值。序列可以循环,或者是连续增加的,直到指定的最大值为止。

创建序列语法如下:create sequence [模式]序列名称[start with 起始数字] [increment by 增量][maxvalue 最大值|nomaxvalue][minvalue 最小值|nominva lue][cycle|nocuyle][cache 数目|nocache][order|noorder]。

具体代码示例如下:

创建表

create table book(

bookId varchar2(4) primary key,

name varchar2(20)

);

创建序列

create sequence book_seq start with 1 increment by 1;

创建触发器

create or replace trigger book_trigger

before insert on book

for each row

begin

select book_seq.nextval into :new.bookId from al;

end ;

添加数据

insert into book(name) values ('cc');

insert into book(name) values ('dd');

commit;

(5)oracle存储过程自增扩展阅读:

在数据表中,有时候需要主键值自动增加,但在Oracle数据库中,没有象Mysql的Autoincrement一样自动增长的数据类型。在实现Oracle数据库字段自增功能时,利用DML触发器来完成。

触发器(trigger)是一些过程,当发生一个特定的数据库事件时就执行这些过程,可以使用触发器扩充引用的完整性。DML即数据操纵语言,用于让用户或程序员使用,实现对数据库中数据的操作。基本的数据操作分成两类四种:检索(查询)和更新(插入、删除、修改)。

触发器类似于函数和过程,其在数据库中以独立身分存在。触发事件可以是对数据库表的DML(insert、update或delete)操作等。



㈥ oracle中如何实现表中数据的自增,越简单越好。

你好!

简单点的方法:
在表中增加一个列,为自增序列,然后执行:

update 表 set 自增序列=rownum;

这样快速,还不会出错。

㈦ oracle数据库表中某自段怎么设置为自增字段

呃,简单点的方法:
在表中增加一个列,为自增序列,然后执行:
update

set
自增序列=rownum;
这样就把以前的3000多万行都编号了,然后再用sequence做序列;
这样快速,还不会出错。

㈧ 请我在 ORACLE 中 如何在 存储过程 中创建一个触发器, 或者在存储过程中建立新的表并为其创建自增主键

自增主键用sequence就好了。

热点内容
a星算法视频 发布:2025-01-22 07:55:01 浏览:878
快手安卓怎么直播 发布:2025-01-22 07:54:58 浏览:937
买服务器搭建vpn 发布:2025-01-22 07:53:21 浏览:808
路由器忘记密码如何解 发布:2025-01-22 07:38:47 浏览:153
5分钟视频编译 发布:2025-01-22 07:36:33 浏览:772
asp执行存储过程 发布:2025-01-22 07:35:55 浏览:126
镇政府搭建服务器 发布:2025-01-22 07:32:13 浏览:1001
安卓系统可以查去过哪里吗 发布:2025-01-22 07:25:05 浏览:27
三星手机怎么设置热点密码 发布:2025-01-22 07:20:11 浏览:38
Ip呼叫服务器 发布:2025-01-22 07:19:32 浏览:633