";由于对象“”的当前状态,操作无效;在Oracle阅读器上

本文关键字:无效 操作 状态 Oracle 于对象 quot 对象 | 更新日期: 2023-09-27 18:26:26

关键在于:

我有这个脚本,在我运行它进行性能测试之前,它绝对没有给我带来任何问题,现在它"在调试期间,每当我尝试运行它时,都会不断向我显示相同的错误:

using (OracleConnection con = new OracleConnection())
{
             //Connect to OracleDB and retreive the first valid, unused SRVID//
            con.ConnectionString = @"Data Source=(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=myhostip)(PORT=1521)))(CONNECT_DATA=(SERVER=DEDICATED)(SERVICE_NAME=MyServerNAme)));User Id=MyUSer;Password=MyPAssword";
            OracleCommand command = new OracleCommand("SELECT MASK_GUID(SWAP_GUID(SRVID)) FROM  MYTable WHERE USED=0 AND ROWNUM = 1", con);
            con.Open();
            OracleDataReader reader = command.ExecuteReader();
            reader.Read();
            ServerID = reader.GetString(0);
            reader.Close();
             //update SRVID in DB as used so further users will not select it
            command.CommandText = "UPDATE MyTable SET USED=1 WHERE SRVID = FIX_GUID('"+ ServerID+"')";
            command.Connection = con;
             command.ExecuteNonQuery();
             reader.Close();
             reader.Dispose();
       con.Close();
       con.Dispose();
}

这就是代码,下面是出错的地方:

  1. ServerID= reader.GetString(0)上,由于对象的当前状态错误,我接收到操作无效。当在调试中掩盖阅读器时,我看到它没有数据行,这可能解释了错误(但这导致了…)

  2. 查询很好。我在数据库上本地运行它,它返回一个有效的值(我复制粘贴它以确保),所以这不是阅读器没有数据的原因。

  3. 这个问题始于一次性能测试,该测试运行了这个脚本大约800次,然后这个错误开始不断出现。。。我测试的系统仍然运行良好,即使在执行需要访问同一数据库的操作时也是如此。

调试器没有显示与此情况有关的其他错误。。。或者说,就这一点而言。

想法?

";由于对象“”的当前状态,操作无效;在Oracle阅读器上

您需要将MaxHttpCollection属性设置为更高的值。