阅读器关闭时尝试调用 Read 无效

bleach001 2011-03-31 03:21:06
页面载入时候分别从两张表里读取数据,调试过程中,能查出第一张的数据,查询第二张表的是后出错了 :阅读器关闭时尝试调用 Read 无效


string sql = "SELECT top 1 accountName, money, date FROM Account WHERE accountName =" + "'" + name + "'" + " ORDER BY date DESC";

using (SqlDataReader reader = DBHelper.ExecuteReader(sql))
{
if (reader.Read()) //这里报错


两张表都用了using 。


...全文
169 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
bleach001 2011-03-31
  • 打赏
  • 举报
回复
最后改了试了很久,就是把第一条查询注释了还是报错,最后我改了下语句

string sql = "SELECT top 1 balance FROM Account WHERE accountName =" + "'" + name + "'" + " ORDER BY date DESC";
SqlDataReader reader = DBHelper.ExecuteReader(sql)//原语句 报错
if(reader.Read())
```
string sql = "SELECT top 1 balance FROM Account WHERE accountName =@name ORDER BY date DESC";
SqlDataReader reader = DBHelper.ExecuteReader(sql,new SqlParameter("@name",name))//这样写就好了


很郁闷的问题
子夜__ 2011-03-31
  • 打赏
  • 举报
回复
用这种
/// <summary>
/// 执行有参的查询 返回DataTable
/// </summary>
/// <returns>返回DataTable</returns>
public static DataTable ReturnDataTable(string cmdtext)
{
SqlConnection cn = new SqlConnection();
cn.ConnectionString = "数据库连接字符串";
DataTable dt = new DataTable();
SqlCommand cmd = new SqlCommand();
cmd = new SqlCommand(cmdtext, cn);
cmd.CommandType = CommandType.Text; ;
SqlDataReader dr = null;
using (dr = cmd.ExecuteReader(CommandBehavior.CloseConnection))
{
dt.Load(dr);
}
return dt;
}

62,046

社区成员

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

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

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

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