簡體   English   中英

將gridview的所有行保存到數據庫asp.net C#

[英]save all rows of gridview to database asp.net c#

我有一個帶有兩列的gridview,其中之一是帶有下拉列表的模板字段。我想通過gridview外部的保存按鈕將所有行保存到數據庫,但是當我單擊它時,它僅保存gridview的第一行。 。如何將整個gridview保存到數據庫?

protected void Button1_Click(object sender, EventArgs e)
        {

            for (int i = 0; i < GridView2.Rows.Count; i++)
            {

                    GridViewRow row = GridView2.Rows[i];

                    string coursecode = DropDownList1.SelectedValue.ToString();
                    string weekno = DropDownList2.SelectedValue.ToString();
                    string day = DropDownList3.SelectedValue;
                    string stid = row.Cells[0].Text;
                    DropDownList ddlstatus = (DropDownList)row.Cells[1].FindControl("DropDownList9");
                    string status = ddlstatus.SelectedValue.ToString();

                    double percentage;
                    if (status == "A")
                    {
                        if (day == "Saturday")
                        {
                            percentage = 6.66;
                        }
                        else
                        {
                            percentage = 3.33;
                        }
                    }
                    else
                    {
                        percentage = 0;
                    }


                    String strConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
                    SqlConnection con = new SqlConnection(strConnString);
                    String query = "insert into Attendance values (@CourseCode, @St_ID, @WeekNo, @Day,@Status, @Percentage)";
                    SqlCommand cmd = new SqlCommand(query, con);
                    cmd.Parameters.AddWithValue("@CourseCode", coursecode);
                    cmd.Parameters.AddWithValue("@WeekNo", weekno);
                    cmd.Parameters.AddWithValue("@Day", day);
                    cmd.Parameters.AddWithValue("@St_ID", stid);
                    cmd.Parameters.AddWithValue("@Status", status);
                    cmd.Parameters.AddWithValue("@Percentage", percentage);
                    con.Open();
                    cmd.ExecuteNonQuery();
                    con.Close();
                    Response.Redirect("~/DoctorAddEditAttendance.aspx");
                }
            }

Redirect循環外,以完成對所有行的處理。

順便說一句,最好的方法是重定向這種方式:

Response.Redirect("~/DoctorAddEditAttendance.aspx", false);
Context.ApplicationInstance.CompleteRequest();

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM