尝试读取OracleDataReader时如何解决“对关闭的对象无效的操作”异常

时间:2019-07-30 14:58:35

标签: c# oracle asp.net-core .net-core

我正在使用.Net Core和Oracle.ManagedDataAccess.Core插件创建一个Web API,该插件访问Oracle数据库以检索Blob字段并将其作为字节数组返回。我创建了一个函数(getBlobfromDB),该函数从SQL数据库上的加密字段获取Oracle连接字符串,进行连接并使用OraleDataReader检索并返回Blob字段。但是,当OraleDataReader尝试读取记录时,出现此异常:“对关闭的对象无效的操作”。

搜索此问题时,最相关的答案是post

但是,我100%确信conn字符串上的用户可以访问,因为那是架构所有者,并且我还尝试将架构所有者添加到Select查询中(SELECT FIELD FROM SCHEMA_OWNER.TABLE WHERE ID =“ “)遇到相同的错误

因此,我尝试了另外两件事,即从同一数据库中的另一个表获取了不同的VARCHAR字段,仍然遇到了相同的错误;并尝试使用其他Oracle数据库,便能够成功检索数据。我注意到服务器上的Oracle版本不同,工作版本为12.2,非工作版本为11.2,这可能是原因吗?我不知道我还能做什么或尝试什么,我会很感激您能给我的任何帮助/建议

这是简化功能

private OracleBlob getBlobfromDB(string sSystem, string sID)
        {
            string sSQL = String.Empty;
            string connString = String.Empty;
            OracleConnection oConn = new OracleConnection();

            if (string.IsNullOrWhiteSpace(sID) || string.IsNullOrWhiteSpace(sSystem) )
            {
                return null;
            }          

            sSQL = "SELECT BLOB_FIELD FROM TABLE WHERE ID = " + sID;
            connString = getConnectionString(sSystem); 

            try
            {
                using (oConn = new OracleConnection(connString))
                { 
                    oConn.Open();
                    OracleCommand oCom = new OracleCommand(sSQL, oConn);                   

                    OracleDataReader oDr = oCom.ExecuteReader();                    
                    if (oDr.HasRows)
                    {      
                        //I'm able to reach to this point before getting the exception
                        oDr.Read();
                        OracleBlob blob = oDr.GetOracleBlob(0);                        
                        // Clean up
                        oDr.Close();
                        oDr.Dispose();
                        oCom.Dispose();
                        return blob;
                    }
                    else
                    {
                        // Clean up
                        oDr.Close();
                        oDr.Dispose();
                        oCom.Dispose();
                        return null;
                    }

                }
            }
            catch (Exception x)
            {
                return null;
            }
            finally
            {
                oConn.Close();
            }
        }

0 个答案:

没有答案