数据库

位置:IT落伍者 >> 数据库 >> 浏览文章

Oracle数据的完整性的嵌套事务调用的研究


发布日期:2022年12月03日
 
Oracle数据的完整性的嵌套事务调用的研究

为了保护数据的完整性我们用了很多的方法比如数据表的主键约束

键约束触发器等等我们今天讨论的就是在处理数据直接的事务的时

保存数据的完整性比如我在一个存储过程中Proc_SaveBill保存一

张单据调用一个函数Func_GenerateCode来生成一个单据的编号假如我

的这个函数是从一个存有最大编号的表中取出的并且把编号加一大家可

能会想象的可能产生的问题就是如果我在Proc_SaveBill中的保存之前通

过Func_GenerateCode得到一个编号如果后面的保存不成功怎么办是不

是就丢了一个编号因为我调用一次Func_GenerateCode就会增加一个编号

那么为了使我们的数据完整不至于丢单就的使用事务的会滚现在

又有问题了存储过程会会滚到函数中嘛!答案是如果函数中有事务或

有commit语句那么是会滚不了的否则可以会滚因为事务是会滚到上

一个committ或rollback之后的所有事物所以我在这里说明是为了提醒大

家考虑事务的嵌套回滚的一些方法但是在存储过程调用存储过程中

果被调用的存储过程执行没有错误那么很遗憾是会滚不了的为了解决

这个问题Oracle中用自治事务来处理上述出现的问题在存储过程的is\as

后面声明PRAGMA AUTONOMOUS_TRANSACTION; 自治事务防止嵌套提交使

事务在自己的事务区内提交或回滚不会影响其他的事务

今天在这里就说这些当然这些是比较基础的给初学者提个醒!

上一篇:Oracle数据库备份与恢复之四:RMAN(备份与恢复管理器)

下一篇:用于企业的Oracle9i真正的应用集群系统配置