在gridview更新编码我得到以下错误?

时间:2013-02-09 09:21:34

标签: c# asp.net

这是我的更新事件代码:

protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
{
    if (con.State == ConnectionState.Closed)
    {
        con.Open();
    }

    GridViewRow row = (GridViewRow)GridView1.Rows[e.RowIndex];
    int Label11 =Convert.ToInt32(((Label)row.FindControl("Label11")).Text);// this is the line m getting error in
    int Label12 = Convert.ToInt32(((Label)row.FindControl("Label12")).Text);
    int Label13 = Convert.ToInt32(((Label)row.FindControl("Label13")).Text);
    TextBox TextBox4 = (TextBox)row.FindControl("TextBox4");
    TextBox TextBox5 = (TextBox)row.FindControl("TextBox5");
    TextBox TextBox6 = (TextBox)row.FindControl("TextBox6");
    TextBox TextBox7 = (TextBox)row.FindControl("TextBox7");
    TextBox TextBox8 = (TextBox)row.FindControl("TextBox8");
    TextBox TextBox9 = (TextBox)row.FindControl("TextBox9");
    TextBox TextBox10 = (TextBox)row.FindControl("TextBox10");
    GridView1.EditIndex = -1;
    SqlCommand cmd = new SqlCommand("update monthly set date='" + TextBox4.Text + "',salary='" + TextBox5.Text + "',ta='" + TextBox6.Text + "',contigency='" + TextBox7.Text + "',nrc='" + TextBox8.Text + "',institcharges='" + TextBox9.Text + "',others='" + TextBox10.Text + "' where autoid='" + Label12 + "'", con);
    cmd.ExecuteNonQuery();
    cmd.Dispose();
    con.Close();
    grid_show();

我得到的错误是FormatException未处理的用户代码 输入字符串的格式不正确。

1 个答案:

答案 0 :(得分:1)

使用可用于Primitive数据类型的TryParse方法。解释SQL注入和ORM框架超出了本答案的范围。

http://social.msdn.microsoft.com/Search/en-US?query=TryParse&ac=8

void Main()
{
    //TryParse function signature
    //bool TryParse(String, Int32) 
    //Above method is for Integer. There are similar methods for all primitive data types

    //TryParse takes String value as an input and parameter as reference

    //Integer example
    int result;
    bool success = int.TryParse("10", out result);
    if(success) Console.WriteLine("Good value {0}", result);


    //DateTime example
    DateTime dtResult;
    success = DateTime.TryParse("01/10/2013", out dtResult);
    if(success) Console.WriteLine("Good date {0}", dtResult);
}