更新SQL Server前端应用程序中的字段时出错

时间:2016-06-24 10:51:39

标签: c# sql asp.net web-applications

我正在开发一个几乎完整的应用程序,除了我的一页。

在页面上是一个gridview,它显示数据库中的数据有效,问题是当用户尝试更新信息时会抛出错误。

这是我的代码 - 有人可以看到我做错了什么以及如何解决这个问题?

protected void OnRowUpdating(object sender, GridViewUpdateEventArgs e)
{
    GridViewRow row = GridView1.Rows[e.RowIndex];

    int Id = Convert.ToInt32(GridView1.DataKeys[e.RowIndex].Values[0]);
    int Period_Id = Convert.ToInt32(GridView1.DataKeys[e.RowIndex].Values[0]);
    int Evo_StockLink = Convert.ToInt32(GridView1.DataKeys[e.RowIndex].Values[0]);

    string Evo_ItemCode = (row.Cells[4].Controls[0] as TextBox).Text;
    string Evo_Description = (row.Cells[5].Controls[0] as TextBox).Text;

    float UnitRate = Convert.ToInt32(GridView1.DataKeys[e.RowIndex].Values[0]);
    float MinRate = Convert.ToInt32(GridView1.DataKeys[e.RowIndex].Values[0]);
    float RateBeforeSevenDays  = Convert.ToInt32(GridView1.DataKeys[e.RowIndex].Values[0]);
    float RateAfterSevenDays = Convert.ToInt32(GridView1.DataKeys[e.RowIndex].Values[0]);

    string constr = ConfigurationManager.ConnectionStrings["constr"].ConnectionString;

    using (SqlConnection con = new SqlConnection(constr))
    {
        using (SqlCommand cmd = new SqlCommand("UPDATE rates SET Period_Id = @Period_Id, Evo_StockLink = @Evo_StockLink, Evo_ItemCode = @Evo_ItemCode, Evo_Description = @Evo_Description, MinRate = @MinRate, RateBeforeSevenDays = @RateBeforeSevenDays, RateAfterSevenDays = @RateAfterSevenDays  WHERE Id = @Id"))
        {
            cmd.Parameters.AddWithValue("@Id", Id);
            cmd.Parameters.AddWithValue("@Period_Id", Period_Id);
            cmd.Parameters.AddWithValue("@Evo_StockLink", Evo_StockLink);
            cmd.Parameters.AddWithValue("@Evo_ItemCode", Evo_ItemCode);
            cmd.Parameters.AddWithValue("@Evo_Description", Evo_Description);
            cmd.Parameters.AddWithValue("@UnitRate", UnitRate);
            cmd.Parameters.AddWithValue("@MinRate", MinRate);
            cmd.Parameters.AddWithValue("@RateBeforeSevenDays", RateBeforeSevenDays);
            cmd.Parameters.AddWithValue("@RateAfterSevenDays", RateAfterSevenDays);

            cmd.Connection = con;
            con.Open();
            cmd.ExecuteNonQuery();
            con.Close();
        }
    }

    GridView1.EditIndex = -1;
    this.BindGrid();
}

显示的错误是:

  

指数超出范围。必须是非负数且小于集合的大小。
  参数名称:index

     

异常详细信息:System.ArgumentOutOfRangeException:索引超出范围。必须是非负数且小于集合的大小。
  参数名称:index

     

来源错误:

     第61行:{
  第62行:GridViewRow行= GridView1.Rows [e.RowIndex];
  第63行:int Id = Convert.ToInt32(GridView1.DataKeys [e.RowIndex] .Values [0]);
  第64行:int Period_Id = Convert.ToInt32(GridView1.DataKeys [e.RowIndex] .Values [0]);
  第65行:int Evo_StockLink = Convert.ToInt32(GridView1.DataKeys [e.RowIndex] .Values [0]);

1 个答案:

答案 0 :(得分:0)

在aspx中确保您拥有DataKeyNames =“Id”,您还使用Datakeys传递所有字段,这会将整个数据库更新为该值。