2013-04-03 76 views
1

我有一個下拉列表與數據庫表中的數據,我想插入與此ddl + 2 texbox字段在另一個表中。插入工作,但總是插入首先默認的dropdownList女巫顯示。我錯過了什麼?dropdownlist插入總是默認值

protected void Page_Load(object sender, EventArgs e) 
      { 


       string connectionString = cs.getConnection(); 
       string query = "SELECT Id, NAME FROM PROFITCATEGORIES"; 
       using (SqlConnection myConnection = new SqlConnection(connectionString)) 
       { 
        myConnection.Open(); 
        SqlCommand command = new SqlCommand(query, myConnection); 
        using (SqlDataReader rdr = command.ExecuteReader()) 
        { 

         DropDownListCategory.DataSource = rdr; 
         DropDownListCategory.DataTextField = "Name"; 
         DropDownListCategory.DataValueField = "ID"; 
         DropDownListCategory.DataBind(); 

        } 
       } 

      } 

      protected void ButtonSave_Click(object sender, EventArgs e) 
      { 
       if (String.IsNullOrWhiteSpace(TextBoxValue.Text)) 
        return; 
       string connectionString = cs.getConnection(); 
       string insertSql = "INSERT INTO profits(Value,DateCreate,IdCategory,IdUser) VALUES(@Value, @DateCreate,@CategoryId,@UserId)"; 

       using (SqlConnection myConnection = new SqlConnection(connectionString)) 
       { 
        myConnection.Open(); 
        SqlCommand command = new SqlCommand(insertSql, myConnection); 
        //параметризация се прави тук за да се избегне SQL Injection 
        command.Parameters.AddWithValue("@Value", TextBoxValue.Text); 
        command.Parameters.AddWithValue("@DateCreate", TextBoxData.Text); 
        command.Parameters.AddWithValue("@CategoryId", DropDownListCategory.SelectedValue); 
        command.Parameters.AddWithValue("@UserId", cui.getCurrentId()); 
        command.ExecuteNonQuery(); 
        //пренасочваме заявката към същата страница за да се видят новите резултати и да се избегне проблем с дублиране на инсерт при рефреш на страницата 
        Response.Redirect("~/Profit.aspx"); 
        myConnection.Close(); 
       } 
       TextBoxValue.Text = string.Empty; 

      } 

回答

2

每當你按ASP:按鈕的頁面被重新加載,和page_load方法中的代碼會再次被初始化。這就是爲什麼默認項目總是插入到數據庫中的原因。

在Page_Load將這個在你的代碼:(如果(Page.IsPostback)!)

protected void Page_Load(object sender, EventArgs e) 
      { 

       if (!Page.isPostback) 
       { 
       string connectionString = cs.getConnection(); 
       string query = "SELECT Id, NAME FROM PROFITCATEGORIES"; 
       using (SqlConnection myConnection = new SqlConnection(connectionString)) 
       { 
        myConnection.Open(); 
        SqlCommand command = new SqlCommand(query, myConnection); 
        using (SqlDataReader rdr = command.ExecuteReader()) 
        { 

         DropDownListCategory.DataSource = rdr; 
         DropDownListCategory.DataTextField = "Name"; 
         DropDownListCategory.DataValueField = "ID"; 
         DropDownListCategory.DataBind(); 

        } 
       } 
       } 

      } 
4

你再結合每個頁面加載列表。將數據綁定代碼包裝在if (!IsPostBack)塊中。

protected void Page_Load(object sender, EventArgs e) 
{ 
    if (!IsPostBack) 
    { 
     // Bind the list here... 
    } 
}