Oracle PL/SQL之自定义函数的读一致性
程序员文章站
2022-05-02 18:22:06
...
当我们将自定义函数应用于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(事务隔离性)
上一篇: php无限分类的图文代码介绍
推荐阅读
-
ORACLE官方SQL语言参考之关于SQL函数的实例讲解
-
oracle复习笔记之PL/SQL程序所要了解的知识点
-
ORACLE官方SQL语言参考之关于用户定义函数的实例讲解
-
Oracle实践--PL/SQL基础之函数
-
Oracle数据库学习之查询的嵌套、事务控制语言、集合操作符和SQL函数讲解
-
Oracle入门--PL/SQL、游标、存储过程、自定义函数、触发器、MyBatis 操作(6)
-
PostgreSQL Oracle 兼容性之 - PL/SQL DETERMINISTIC 与PG函数稳定性(immutable, stable, volatile)...
-
ORACLE官方SQL语言参考之关于SQL函数的实例讲解
-
Oracle 11g 的PL/SQL函数结果缓存
-
oracle复习笔记之PL/SQL程序所要了解的知识点