我在一个方法上有这个代码:
DataGrid2.DataSource = Show1(Convert.ToInt32(Request.QueryString["Cr"]));
DataGrid2.DataBind();
这是分配给数据源的 show 方法:
static SqlConnection sqlConntest = new SqlConnection( ConfigurationSettings .AppSettings["conn"].ToString ()
);
public static SqlDataReader Show1(int cr)
{
SqlDataReader dr;
SqlCommand cmd = new SqlCommand();
cmd.Connection = sqlConntest;
cmd.CommandType = CommandType.StoredProcedure;
cmd.CommandText = "sp1";
cmd.Parameters.Add("@Cr", SqlDbType.Int);
cmd.Parameters["@Cr"].Value = crewID;
sqlConntest.Open();
dr = cmd.ExecuteReader();
return dr;
}
当我运行程序时,我收到错误消息:
“ExecuteReader 需要一个打开且可用的连接。连接的当前状态为关闭”
为什么会发生这种情况,我该如何解决?谢谢。