未从下拉框中获取选定值

时间:2012-03-27 05:42:50

标签: c# asp.net

我遇到问题从我的下拉框中获取正确的值。基本上我所拥有的是一个带有下拉列表的程序,该列表中填充了保存在数据库表中的名称。用户从下拉框中选择一个名称,然后单击一个按钮从数据库中删除该名称。我遇到的问题是,无论选择哪个名称,都会从下拉框中删除名字(索引为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());
        }
    }
}

2 个答案:

答案 0 :(得分:2)

您可能正在填充Page_Load函数中的下拉列表,并且您没有Page.IsPostBack检查。因此,每次再次填充列表时。将人口代码更改为:

    protected void Page_Load(object sender, EventArgs e)
    {
        if (!Page.IsPostBack)
        {
            LoadTable();
        }


    }

答案 1 :(得分:0)

请尝试使用ddlNames.SelectedItem.Value。