数据库

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

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


发布日期:2021年12月13日
 
Oracle数据库为了数据的完整性的嵌套事务调用的研究

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

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

上一篇:在Oracle ERP中导数据(BOM清单)

下一篇:基于Oracle的高性能动态SQL程序开发