oracle 存储过程 是一个事务

来源:互联网 发布:无法连接到sql server 编辑:程序博客网 时间:2024/05/29 07:59

之前做过有关oracle触发器的东西,知道触发器其实就是一个事务,当出现异常或错误时,会回滚,恢复到之前的状态,对于存储过程呢,我也觉得这肯定是也是事务,但是为了证明我所想的,于是就做了一个非常简单的测试procedure

随便拿数据库中的一个table做测试,代码如下:

create or replace procedure testTransaction(  v_id in varchar2  )  is  v_s varchar2(50);begin insert into code_dj(dm,mc) values('3','测试'); select barcodeId into v_s from ptparts where barcodeId=v_id;//找不到数据时,会报data not found错误end testTransaction;
当找不到数据时,也就是存储过程报错时,观察code_js是否真的插入了新的数据,运行一下就知道,当然是没有了啊,所有可以推断oracle存储过程就是一个事务

这里说明一下,如果不想当存储过程发生错误或异常时,回滚所有,可以看一下自治事务,在这里我就不讲了哈,亲们自己google吧!


哎呀,我啥时候才能把这个系统做完,然后去找工作啊大哭

0 0
原创粉丝点击