ora-01000 maximum open cursors exceeded

根本原因在于你打开的cursors(游标),超出了数据库规定的最大值

1、通过命令查看数据库限定的最大值:在oracle终端下:sqlplus /nolog

2、conn /as sysdba;

3、show parameter open_cursor;得到最大值,默认是300

解决方法:你在打开一个游标的时候,记得关闭它,可以加代码:

getSqlMapClientTemplte.getSqlMapClient.commitTransaction();

我的错误是:在一次事务中连续打开两个游标,一个是update语句,另一个是insert语句,而且是批量执行,后果可想而知。

所以让它们每个执行100次就够了,两个一共也就200次,这样就没有超过最大值300。

你明白没有?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值