数据库

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

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


发布日期:2018年04月11日
 
Oracle数据完整性嵌套事务调用分析研究
本文分析一个问题的多种可能读者可以根据现象来判断您属于那种情况来最短时间内解决问题

为了保护数据的完整性我们用了很多的方法比如数据表的主键约束外键约束触发器等等我们今天讨论的就是在处理数据直接的事务的时候保存数据的完整性

比如我在一个存储过程中Proc_SaveBill保存一张单据调用一个函数Func_GenerateCode来生成一个单据的编号假如我的这个函数是从一个存有最大编号的表中取出的并且把编号加一大家可能会想象的可能产生的问题就是如果我在Proc_SaveBill中的保存之前通过Func_GenerateCode得到一个编号如果后面的保存不成功怎么办是不是就丢了一个编号因为我调用一次Func_GenerateCode就会增加一个编号的那么为了使我们的数据完整不至于丢单就会使用事务会滚

现在又有问题了存储过程会会滚到函数中嘛?

答案是如果函数中有事务或有commit语句那么是会滚不到否则可以会滚因为事务是会滚到上一个committ或rollback之后的所有事物所以我在这里说明是为了提醒大家考虑事务的嵌套回滚的一些方法但是在存储过程调用存储过程中如果被调用的存储过程执行没有错误那么很遗憾是会滚不了的为了解决这个问题Oracle中用自治事务来处理上述出现的问题在存储过程的is\as后面声明PRAGMA AUTONOMOUS_TRANSACTION 自治事务防止嵌套提交使事务在自己的事务区内提交或回滚不会影响其他的事务

上一篇:复杂应用环境监控ORACLE数据库性能

下一篇:Transaction的完整性控制,实现仅COMMIT一部份数据