Oracle PL/SQL之自定义函数的读一致性

WBOY
发布: 2016-06-07 17:02:49
原创
771 人浏览过

当我们将自定义函数应用于sql语句中,而该sql又需要执行很长时间,并且在这段时间中恰好又有其他dml会更改该sql中的某些表时,这

读一致性即确保查询的结果与发起查询的时刻的数据一致,不管在此查询期间其他事务有没有更改数据。

首先假设我们有如下函数用来根据部门id求该部门的总薪资:

然后我们开个session(s1),,执行如下查询(q1):

在q1执行的过程中,我们又开个新的session(s2),执行更新命令并提交:

接着回到s1,看q1的执行结果:

我们发现sum(sal)和sum2(deptno)的结果不一致。

当我们将自定义函数应用于sql语句中,而该sql又需要执行很长时间,并且在这段时间中恰好又有其他dml会更改该sql中的某些表时,这种不一致就会体现出来。 

关于如何避免这种不一致,可以使用SET TRANSACTION READ ONLY,详细内容可参看我下面的这篇文章:

Oracle PL/SQL之SET TRANSACTION READ ONLY(事务隔离性)

linux

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!