当前位置: 代码迷 >> C# >> 急求[InvalidOperationException: 无效操作。连接被关闭。解决思路
  详细解决方案

急求[InvalidOperationException: 无效操作。连接被关闭。解决思路

热度:52   发布时间:2016-05-05 02:38:07.0
急求[InvalidOperationException: 无效操作。连接被关闭。
    private OracleConnection con;//!与数据的链接
        private OracleCommand cmd;//
        private void OpenConnection()
        {
            con = new OracleConnection(connectionString);//一个OracleConnection代表与数据库的一个连接,被数据库连接池所管理
            cmd = con.CreateCommand();//创建并返回一个与OraclConnection相关联的OracleCommand对象
    
            try
            {
                con.Open();
            }
            catch (Exception ex)
            {
             
                Console.WriteLine(ex.Message);
              
            }
           
        }

        private void CloseConnection()
        {
            if (con.State == ConnectionState.Open) //如果与数据库的连接仍然打开
            {
                con.Close();
            }
        }




 public string[] QuerySinglePara(Sensor ss)//查询数据库
        {
            OpenConnection();
            string[] result = new string[2];
            string sql = "select value,savetime from(select * from w_data where deviceid=:sensor_serialnum order by savetime desc) where rownum=1";//获取展厅最新的门磁等状态
            cmd.CommandText = sql;
            cmd.Parameters.AddWithValue(":sensor_serialnum", ss.sensor_serialnum);
            OracleDataReader oreader = cmd.ExecuteReader();//异常导致中断,出错的地方

            oreader.Read();
            try
            {
                result[0] = oreader.GetString(0);//获取的数据
                result[1] = oreader.GetDateTime(1).ToString();
            }
            catch (Exception e) //说明没有记录
            {

                result[0] = e.Message;//若是出现异常就报错
            }
            finally
            {
                oreader.Close();//必须关闭,否则会报异常(游标数超过最大值 )
                CloseConnection();
            }
            return result;
        }
------解决思路----------------------
你单独调试一下OpenConnection方法,看看数据库是否被打开了?
------解决思路----------------------
OpenConnection();
这个connection打开了么
------解决思路----------------------
引用:
是不是我的异常没有处理?

你尝试去处理了
try
{
    con.Open();
}
但处理的方式比没处理还要糟糕,你把异常吃掉了。
我们偶尔是会把一些异常吃掉的,但那是看情况的,前提是绝对不能引起其他异常。
catch (Exception ex)
{
   Console.WriteLine(ex.Message);
}
我建议你画下流程图,看下你的代码和你设计的思路是否一致。
------解决思路----------------------
报的错误很明确,
就是open的时候出问题了
后面又继续调用连接进行了相关操作

------解决思路----------------------
你这个将connection设置为全局变量,然后异常就会出的各种稀奇古怪,你为啥要写在全局变量里呢,然后你贴代码又是只贴一小部分出来
  相关解决方案