博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ora-1493,no data found
阅读量:6851 次
发布时间:2019-06-26

本文共 907 字,大约阅读时间需要 3 分钟。

  hot3.png

按照这样的写法,是有可能出现ora-1493,no data found的情况的:

SELECT sid, serial#

  INTO v_sid, v_serial#
  FROM v$session
WHERE sid =
       (SELECT MAX(sid) FROM v$session WHERE audsid = userenv('sessionid'));

 

(1)我们来看最里层的条件是audsid = userenv('sessionid'),audsid是用于审计的session id,每次非系统用户登陆时,会取AUDSES$这个序列的值。请注意,这里是要非系统用户的登陆,才能获得AUDSES$这个序列的值作为audsid。如果是系统的用户,如sys用户登陆或者后台进程,就不会获得AUDSES$序列的值,而获得的值是0。因此,如果你去查询v$session,你总会发现有多个audsid值为0的进程。

(2)如果是以job的方式发起,oracle认为是在数据库服务器端发起的,是系统用户。虽然发起job的用户不是sys,但是由于是在数据库服务器端发起,oracle仍然认为是系统用户,因此audsid为0。

(3)我们现在来具体看看我们的情况,有job发起,因此audsid是0。但数据库中肯定有多个后台进程或者sys用户进程,因此肯定有多个audsid为0的进程。然后,我们取的是这些进程中最大的那个sid,即sql中的MAX(sid),如果刚好取到的这个最大的sid的进程,又恰巧是那些会唤醒/退出的进程:如archive进程,archive进程可能在归档完退出,等待下一次的唤醒;如job进程,一个job跑完之后就退出。那么我们此时选择到的sid就有可能在向上一层sql递归时,已经退出不存在了。因此报错no data found。

 

建议:

在job中不要用audsid = userenv('sessionid'))来获取本session的sid信息,可以采用v$mystat获得本session的sid。

转载于:https://my.oschina.net/thc/blog/310490

你可能感兴趣的文章
《Git权威指南》读书笔记 第四章 git初始化
查看>>
《Head first HTML与CSS 第二版》读书笔记 第九章 盒模型
查看>>
《Python面向对象……》之目录
查看>>
集群入门简析及LB下LVS详解
查看>>
Linux与GPT
查看>>
管理或技术
查看>>
分配到弱属性;对象将在赋值之后释放
查看>>
java作用域public ,private ,protected 及不写时的区别
查看>>
until循环语句
查看>>
Android桌面悬浮窗进阶,QQ手机管家小火箭效果实现
查看>>
提高用户体验方式:饥饿营销
查看>>
Java8中的LocalDateTime工具类
查看>>
Exchange 2013 PowerShell创建自定义对象
查看>>
RAID-10 阵列的创建(软)
查看>>
javaScript的调试(四)
查看>>
nginx不使用正则表达式匹配
查看>>
利用putty进行vnc + ssh tunneling登录
查看>>
hadoop1.x作业提交过程分析(源码分析第二篇)
查看>>
默认安装vsftpd后
查看>>
《Redis设计与实现》读书笔记
查看>>