忘记密码   免费注册 查看新帖 | 论坛精华区

ChinaUnix.net

  平台 论坛 博客 认证专区 大话IT 视频 徽章 文库 沙龙 自测 下载 频道自动化运维 虚拟化 储存备份 C/C++ PHP MySQL 嵌入式 Linux系统
最近访问板块 发新帖
查看: 24248 | 回复: 5

急急,ORA-01013错误。高手指点下 [复制链接]

论坛徽章:
0
发表于 2011-06-21 09:51 |显示全部楼层
我有好几个应用程序操作oracle数据库,一直都没有问题,
最近几天没一天都有2、3次在插入数据时候报ORA-01013,这个时候可以看到这几个应用程序操作都卡在那里,
再查表的死锁状况,有1到2个表的locked_mode为3,但我的应用是不会互锁的,因为各个应用操作的表是不一样的,可以监控到当时的情况

sid         locked_mode        object_name
12              3                          T1
15                3                          T2


在监控当时的sql操作语句
select sid,user_name,sql_text from v$open_cursor where sid in (select sid from (select sid,serial#,username,program  from v$session where status='ACTIVE'));

sid     user_name     sql_text
12           user1           insert T1 ...
12           user1           insert  T1 ...
15            user1           insert T2 ...
15            user1           insert T2 ...
15            user1           insert T2 ....
15            user1           insert T2 ....

我一个程序里插入语句是一个事务操作  begin_ran(); insert T1... ; commit() ;
为什么监控到操作有多条呢?

过几分钟后,这里的插入大多数成功了,其中的一、二条不成功,程序会报ORA-01013错误。

我的数据库是oracle8,已经用了2、3年了,整个数据库的数据量也是有点大的,但操作的表是新建的表。
有没有哪位高手帮忙解决下。

论坛徽章:
0
发表于 2011-06-21 10:32 |显示全部楼层
本帖最后由 tacsoft 于 2011-06-21 10:35 编辑

Error:
ORA-01013: user requested cancel of current operation

Cause:
You interrupted an Oracle operation by pressing Ctrl-C or by canceling the operation through another method (ie: front-end application).

Action:
The options to resolve this Oracle error are:
1.The current operation has been terminated by the user. There is no course of action to take. This message is informational only.
2.This error may also have been caused by a timeout in a sql pass-through query. To resolve this error, properties of the timeout parameter need to be changed to a higher value.


按照Oracle提示,有两个原因,一个是用户主动终止,我觉得这个可能不大。
第二个可能性比较大,就是你运行的语句超时了,你的不定期出现错误更像这种情况,解决办法是调整timeout的值。这样发生超时的几率就会降低。

论坛徽章:
0
发表于 2011-06-21 10:56 |显示全部楼层
谢谢,超时设置我试过了。因为这个一卡就是几分钟的,超时设置不起作用。

而且我在sqlplus下插入数据的时间都是很短
已用时间:  00: 00: 00.31

我怀疑是什么oralce操作造成在某一时间点上插入数据卡住了,可是咋么找也找不到大的操作。

网上有的说是bug,需要打补丁。我不知道哪里找补丁。

论坛徽章:
0
发表于 2011-06-21 11:06 |显示全部楼层
不像BUG,因为如果是BUG的话,应该都不行,你这只有一部分不行。有可能你的数据库压力比较大在瞬间,我觉得也许在脚本里适当设置点延时也许好一点。
如果做数据库优化,你这么低的Oracle版本,也没有顾问程序可用,基本上就要全天监控了,而且数据库做这么大动作,风险也大啊。
这个版本Oracle还有支持吗?

论坛徽章:
51
2015七夕节徽章
日期:2015-08-24 11:17:25ChinaUnix专家徽章
日期:2015-07-20 09:19:30每周论坛发贴之星
日期:2015-07-20 09:19:42ChinaUnix元老
日期:2015-07-20 11:04:38荣誉版主
日期:2015-07-20 11:05:19巳蛇
日期:2015-07-20 11:05:26CU十二周年纪念徽章
日期:2015-07-20 11:05:27IT运维版块每日发帖之星
日期:2015-07-20 11:05:34操作系统版块每日发帖之星
日期:2015-07-20 11:05:36程序设计版块每日发帖之星
日期:2015-07-20 11:05:40数据库技术版块每日发帖之星
日期:2015-07-20 11:05:432015年辞旧岁徽章
日期:2015-07-20 11:05:44
发表于 2011-06-22 12:44 |显示全部楼层
可能死锁了。

论坛徽章:
0
发表于 2016-12-29 17:02 来自手机 |显示全部楼层
解决了么,我也遇到同样问题

论坛徽章:
0
发表于 2016-12-29 17:02 来自手机 |显示全部楼层
解决了么,我也遇到同样问题
您需要登录后才可以回帖 登录 | 注册

本版积分规则

久等啦!10张门票开启你的DTCC2017之旅

2017中国数据库技术大会将于2017年5月11-13日如约而至,本届大会以“数据驱动•价值发现”为主题,共设定2大主场和21个技术专场,云集海内外120+位技术大牛,共同探讨Oracle、MySQL、NoSQL、云端数据库、区块链、深度学习等领域的前瞻性热点话题。
即日起,填写DTCC2017会前调查问卷,即有机会赢取价值2600元的大会门票1张!仅限10张!
----------------------------------------
活动截止时间:2017年5月5日统一公布

问卷入口>>
  

北京皓辰网域网络信息技术有限公司. 版权所有 京ICP证:060528号 北京市公安局海淀分局网监中心备案编号:1101082001
广播电视节目制作经营许可证(京) 字第1234号 中国互联网协会会员  联系我们:
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP