急求[InvalidOperationException: 无效操作。连接被关闭。

云碧霄 2015-10-13 10:15:10
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;
}
...全文
1011 11 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
云碧霄 2015-10-14
  • 打赏
  • 举报
回复
我测试了,运行Openconnection.open到中断
threenewbee 2015-10-14
  • 打赏
  • 举报
回复
OpenConnection();
这个connection打开了么
正怒月神 2015-10-14
  • 打赏
  • 举报
回复
数据库的链接地址对吗?
xian_wwq 2015-10-14
  • 打赏
  • 举报
回复
报的错误很明确,
就是open的时候出问题了
后面又继续调用连接进行了相关操作
  • 打赏
  • 举报
回复
你这个将connection设置为全局变量,然后异常就会出的各种稀奇古怪,你为啥要写在全局变量里呢,然后你贴代码又是只贴一小部分出来
masanaka 2015-10-14
  • 打赏
  • 举报
回复
引用 7 楼 u010886216 的回复:
是不是我的异常没有处理?

你尝试去处理了
try
{
con.Open();
}
但处理的方式比没处理还要糟糕,你把异常吃掉了。
我们偶尔是会把一些异常吃掉的,但那是看情况的,前提是绝对不能引起其他异常。
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
我建议你画下流程图,看下你的代码和你设计的思路是否一致。
云碧霄 2015-10-14
  • 打赏
  • 举报
回复
是不是我的异常没有处理?
云碧霄 2015-10-14
  • 打赏
  • 举报
回复
masanaka 2015-10-13
  • 打赏
  • 举报
回复

try
{
con.Open();
}
catch (Exception ex)
{

Console.WriteLine(ex.Message);

}


你这个有问题,数据库连接异常后,后面的代码继续执行了。
ajianchina 2015-10-13
  • 打赏
  • 举报
回复
数据库连接状态的判断方式最好是改一下,两个地方,然后重启动项目进行调试看一下。

private void OpenConnection()
{
	con = new OracleConnection(connectionString);//一个OracleConnection代表与数据库的一个连接,被数据库连接池所管理
	cmd = con.CreateCommand();//创建并返回一个与OraclConnection相关联的OracleCommand对象

	try
	{
		if (con.State != ConnectionState.Open)
		{
			con.Open();
		}
	}
	catch (Exception ex)
	{
		Console.WriteLine(ex.Message);
	}
   
}

private void CloseConnection()
{
	if (con.State != ConnectionState.Close) 
	{
		con.Close();
	}
}
ajianchina 2015-10-13
  • 打赏
  • 举报
回复
你单独调试一下OpenConnection方法,看看数据库是否被打开了?

111,094

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • AIGC Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧