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

今天尝试封装了一些标准数据库操作,也为以后能自己做一套.dll动态链接库做准备。

却无奈遇到了一个问题

class SQLHelper

{

public static SqlDataReader ExecuteReader(string sql, params SqlParameter[] parameters)
{
string connStr = ConfigurationManager.ConnectionStrings["ConStr"].ConnectionString;
using (SqlConnection conn = new SqlConnection(connStr))
{
conn.Open();
using (SqlCommand cmd = conn.CreateCommand())
{
cmd.CommandText = sql;
foreach (SqlParameter sqlParameter in parameters)
{
cmd.Parameters.Add(sqlParameter);
}
return cmd.ExecuteReader();
}
}
}

private void btnExecuteReader_Click(object sender, EventArgs e)
{
SqlDataReader reader = SQLHelper.ExecuteReader("select * from T_person");
while (reader.Read())
{
string name=reader.GetString(reader.GetOrdinal("name"));
MessageBox.Show(name);
}
}

原因很简单

DataReader相当于一个只能向前的读取器,在读取的时候你不能conn.close(),而在函数调用结束时,reader已经被Close()了。
因此,一般的做法是返回一个IList。

当然还有更一般的做法:

因为SqlDataReader对于小数据量的数据来说带来的只有麻烦,有点可疑忽略不计。

所以改而使用DataSet,将查询结果填充到本地内存,这样即使链接断开,也没有影响。

更改如下;

private void btnDataset_Click(object sender, EventArgs e)
{
string connStr = ConfigurationManager.ConnectionStrings["ConStr"].ConnectionString;
using (SqlConnection conn = new SqlConnection(connStr))
{
conn.Open();
using (SqlCommand cmd = conn.CreateCommand())
{
cmd.CommandText = "select * from T_person";
DataSet dataSet=new DataSet();
SqlDataAdapter adapter=new SqlDataAdapter(cmd);
adapter.Fill(dataSet);
DataTable table=dataSet.Tables[0];
for (int i = 0; i < table.Rows.Count;i++ )
{
DataRow row = table.Rows[i];
string name = Convert.ToString(row["name"]);
MessageBox.Show(name);
}
}
}
}


大家也可以看看csdn上的一个帖子

http://topic.csdn.net/u/20090419/23/5e5030f4-7201-430a-a786-3dd7d4f1699a.html

posted @ 2010-12-17 21:21  羽落无声  阅读(4295)  评论(1编辑  收藏  举报