try
{
String empid1 = Request.QueryString["MyText"];
int empid = int.Parse(empid1);
string constr = System.Configuration.ConfigurationManager.ConnectionStrings["EmployeeDatabase"].ConnectionString;
SqlConnection con = new SqlConnection(constr);
con.Open();
SqlCommand cmd = new SqlCommand("ReportingManagers", con);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.Add("@EmpID", SqlDbType.Int, 0).Value = empid;
SqlDataReader dr = cmd.ExecuteReader();
dr.Read();
LinkButton3.Text = string.Empty;
int i = 1;
while(dr.Read())
{
TreeNode parentNode = new TreeNode("L" + i++ + "Manager : " + dr["Emp_Name"].ToString());
parentNode.Value = dr["Emp_ID"].ToString();
TreeView1.Nodes.Add(parentNode);
parentNode.ChildNodes.Add(new TreeNode("Short ID : " + dr["Short_ID"].ToString()));
parentNode.ChildNodes.Add(new TreeNode("EmpID : " + dr["Emp_ID"].ToString()));
// LinkButton3.Text = "Reporting Managers";
}
DataTable dt = new DataTable();
dt.Load(dr);
if (dt.Rows.Count > 1)
{
LinkButton3.Text = "Reporting Managers";
}
dr.Close();
con.Close();
}
请解释为什么我的 if 循环没有在上面的代码中执行。我可以看到,在数据表 dt 中,我的行数为 '0',但我的博士显示有行是正确的。我不想在这个场景中使用 sql 适配器。
在这种情况下如何捕获数据表的行数?