我遇到问题从我的下拉框中获取正确的值。基本上我所拥有的是一个带有下拉列表的程序,该列表中填充了保存在数据库表中的名称。用户从下拉框中选择一个名称,然后单击一个按钮从数据库中删除该名称。我遇到的问题是,无论选择哪个名称,都会从下拉框中删除名字(索引为0)。
这让我相信单击按钮时会重置SelectedIndex,我不明白。
删除按钮代码:
protected void cmdDelete_Click(object sender, EventArgs e)
{
using (SqlConnection conn = new SqlConnection(@"Server=myname-PC\SQLEXPRESS;Database=dbNames;Trusted_Connection=True;"))
{
try
{
conn.Open();
SqlCommand comm = new SqlCommand("DELETE FROM Names WHERE FirstName=@FirstName AND LastName=@LastName", conn);
char[] delims = new char[1];
delims[0] = ' ';
//lblGreeting.Text = cblNames.
lblGreeting.Text = ddlNames.SelectedItem.Text;
string[] names = ddlNames.SelectedValue.ToString().Split(delims);
string fname = names[0];
string lname = names[1];
comm.Parameters.Add(new SqlParameter("@FirstName", fname));
comm.Parameters.Add(new SqlParameter("@LastName", lname));
comm.ExecuteNonQuery();
conn.Close();
LoadTable();
}
catch (Exception ex)
{
Response.Write("Delete Table: "+ex.ToString());
}
}
}
感谢任何帮助。
我不确定如果第一次没有呈现页面应该改变什么,或者为什么会改变我希望该功能执行的操作。在单击按钮后调用它,并且应该在再次呈现表之前获取值。我将包括LoadTable()以防它有用:
protected void LoadTable()
{
using (SqlConnection conn = new SqlConnection(@"Server=myname-PC\SQLEXPRESS;Database=dbNames;Trusted_Connection=True;"))
{
try
{
conn.Open();
using (SqlCommand comm = new SqlCommand("SELECT * FROM Names",conn))
{
SqlDataReader rd = comm.ExecuteReader();
string fname="";
string lname="";
ddlNames.Items.Clear();
while (rd.Read())
{
fname = rd.GetString(0);
lname = rd.GetString(1);
ddlNames.Items.Add(fname + " " + lname);
}
rd.Close();
}
}
catch (Exception ex)
{
Response.Write("Load Table: "+ex.ToString());
}
conn.Close();
}
}
另外两个功能:
protected void Page_Load(object sender, EventArgs e)
{
LoadTable();
}
protected void cmdAdd_Click(object sender, EventArgs e)
{
using (SqlConnection conn = new SqlConnection(@"Server=myname-PC\SQLEXPRESS;Database=dbNames;Trusted_Connection=True;"))
{
try
{
conn.Open();
char[] splits = new char[1];
splits[0] = ' ';
string fname = txtName.Text.Split(splits)[0];
string lname = txtName.Text.Split(splits)[1];
SqlCommand comm = new SqlCommand("INSERT INTO Names VALUES(@FirstName,@LastName)",conn);
comm.Parameters.Add("@FirstName", fname);
comm.Parameters.Add("@LastName", lname);
comm.ExecuteNonQuery();
conn.Close();
LoadTable();
}
catch(Exception ex)
{
Response.Write("Add Name: "+ex.ToString());
}
}
}
答案 0 :(得分:2)
您可能正在填充Page_Load函数中的下拉列表,并且您没有Page.IsPostBack检查。因此,每次再次填充列表时。将人口代码更改为:
protected void Page_Load(object sender, EventArgs e)
{
if (!Page.IsPostBack)
{
LoadTable();
}
}
答案 1 :(得分:0)
请尝试使用ddlNames.SelectedItem.Value。