为了保护数据的完整性我们用了很多的方法比如数据表的主键约束外
键约束触发器等等我们今天讨论的就是在处理数据直接的事务的时
候保存数据的完整性比如我在一个存储过程中Proc_SaveBill保存一
张单据调用一个函数Func_GenerateCode来生成一个单据的编号假如我
的这个函数是从一个存有最大编号的表中取出的并且把编号加一大家可
能会想象的可能产生的问题就是如果我在Proc_SaveBill中的保存之前通
过Func_GenerateCode得到一个编号如果后面的保存不成功怎么办是不
是就丢了一个编号因为我调用一次Func_GenerateCode就会增加一个编号
的那么为了使我们的数据完整不至于丢单就的使用事务的会滚现在
又有问题了存储过程会会滚到函数中嘛!答案是如果函数中有事务或
有commit语句那么是会滚不了的否则可以会滚因为事务是会滚到上
一个committ或rollback之后的所有事物所以我在这里说明是为了提醒大
家考虑事务的嵌套回滚的一些方法但是在存储过程调用存储过程中如
果被调用的存储过程执行没有错误那么很遗憾是会滚不了的为了解决
这个问题Oracle中用自治事务来处理上述出现的问题在存储过程的is\as
后面声明PRAGMA AUTONOMOUS_TRANSACTION; 自治事务防止嵌套提交使
事务在自己的事务区内提交或回滚不会影响其他的事务
今天在这里就说这些当然这些是比较基础的给初学者提个醒!