如何处理返回类型为OleDbDataReader的方法?

牙签是竹子的 2008-08-08 03:21:18
函数如下:
public static OleDbDataReader getRead(string sql)//返回一个数据集
{
OleDbDataReader myReader = null;
try
{
OleDbCommand myCommand = new OleDbCommand(sql, con);
Open();
myReader = myCommand.ExecuteReader(CommandBehavior.CloseConnection);
Close();
}
catch (Exception ex)
{
Close();
myReader = null;
}
finally
{
Close();
}
return myReader;
}


然后我是这么调用的
OleDbDataReader myReader = getRead(“select * from table”);
if (myReader.Read())//当程序走到这里时提示说:阅读器关闭时 Read 的尝试无效。
{
tbUserName.Text = myReader.GetString(0);
tbName.Text = myReader.GetString(1);
tbTel.Text = myReader.GetString(2);
tbMobile.Text = myReader.GetString(3);
tbMail.Text = myReader.GetString(4);
}


什么原因?
...全文
48 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
whoami333 2008-08-08
  • 打赏
  • 举报
回复
这种方式,恐怕你的数据库连接要是全局的,并且不能关闭。
xhan2000 2008-08-08
  • 打赏
  • 举报
回复
问题很明显,返回之前,执行了close(),所以出错

取reader必须打开连接

根据你的情况,最好返回datatable,程序稍微修改一下就行了
牙签是竹子的 2008-08-08
  • 打赏
  • 举报
回复
to:yfqvip 不行,还是原来的错误
满衣兄 2008-08-08
  • 打赏
  • 举报
回复

if(myReader!=null)
{
if (myReader.Read())//当程序走到这里时提示说:阅读器关闭时 Read 的尝试无效。
{
tbUserName.Text = myReader.GetString(0);
tbName.Text = myReader.GetString(1);
tbTel.Text = myReader.GetString(2);
tbMobile.Text = myReader.GetString(3);
tbMail.Text = myReader.GetString(4);
}
}

62,074

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

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