急求[InvalidOperationException: 无效操作。连接被关闭。解决思路
急求[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设置为全局变量,然后异常就会出的各种稀奇古怪,你为啥要写在全局变量里呢,然后你贴代码又是只贴一小部分出来
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设置为全局变量,然后异常就会出的各种稀奇古怪,你为啥要写在全局变量里呢,然后你贴代码又是只贴一小部分出来