Sinclai 2015-08-14 02:02 采纳率: 0%
浏览 2152
已结题

C#无法使用更新编辑GridView1_RowUpdating

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;
using System.Data.SqlClient;

public partial class sicao_SC_8 : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
SqlConnection conn = new SqlConnection();
conn.ConnectionString = "Data Source=(local);Initial Catalog=SC;User ID=lxk;Password=123";
conn.Open();
string sql = "select * from student";
SqlCommand cmd = new SqlCommand(sql, conn);
SqlDataAdapter dapt = new SqlDataAdapter(cmd);
DataSet ds = new DataSet();
dapt.Fill(ds, "student");
GridView1.DataSource = ds.Tables["student"];
GridView1.DataBind();
conn.Close();
dapt.Dispose();

}
//添加
protected void Button1_Click(object sender, EventArgs e)
{
    string stu_name = Name.Text.ToString();
    int stu_number = Convert.ToInt32(Number.Text);
    SqlConnection conn = new SqlConnection();
    conn.ConnectionString = "Data Source=(local);Initial Catalog=SC;User ID=lxk;Password=123";
    conn.Open();
    string sql = "insert into student(stu_name,stu_number)values('"+stu_name+"','"+stu_number+"')";
    SqlCommand cmd = new SqlCommand(sql, conn);
    cmd.ExecuteNonQuery();
    Response.Write("<script>alert('添加信息成功!');window.location.href='SC-8.aspx'</script>");
    GridView1.DataBind();
    conn.Close();
}
protected void GridView1_SelectedIndexChanged(object sender, EventArgs e)
{

}
//翻页
protected void GridView1_PageIndexChanging(object sender, GridViewPageEventArgs e)
{
    GridView1.PageIndex = e.NewPageIndex;
    this.DataBind();
}
//编辑
protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e)
{
    GridView1.EditIndex = e.NewEditIndex;
    this.DataBind();
}
//取消
protected void GridView1_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e)
{
    GridView1.EditIndex =-1;
    this.DataBind();
}
//更新
protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
{
    int id = Convert.ToInt32(GridView1.DataKeys[e.RowIndex].Values[0]);
    string stu_name = ((TextBox)(this.GridView1.Rows[e.RowIndex].Cells[1].Controls[0])).Text;
    int stu_number = Convert.ToInt32(((TextBox)(this.GridView1.Rows[e.RowIndex].Cells[2].Controls[0])).Text);
    string sql="UPDATE student set stu_name='"+stu_name+"',stu_number='"+stu_number+"' where id='"+id+"'";
    SqlConnection conn = new SqlConnection();
    conn.ConnectionString = "Data Source=(local);Initial Catalog=SC;User ID=lxk;Password=123";
    conn.Open();
    SqlCommand cmd = new SqlCommand(sql, conn);
    cmd.ExecuteNonQuery();
    conn.Close();
}
//删除
protected void GridView1_RowDeleting(object sender, GridViewDeleteEventArgs e)
{
    string sqlstr = "delete from student where id='" + GridView1.DataKeys[e.RowIndex].Values.ToString() + "'";
    string strcon = "Data Source=(local);Database=SC;User ID=lxk;Password=123";
    SqlConnection sqlcon = new SqlConnection(strcon);
    SqlCommand sqlcom = new SqlCommand(sqlstr, sqlcon);
    sqlcon.Open();
    sqlcom.ExecuteNonQuery();
    Response.Write("<script>alert('删除信息成功!');window.location.href='SC-8.aspx'</script>");
    GridView1.DataBind();
    sqlcon.Close();
}

}

  • 写回答

1条回答 默认 最新

  • EAison 2015-08-14 10:05
    关注

    绑定数据不应该写在页面加载里 应该放在一个方法中 这是一个错误 因为你更新之后需要页面刷新才能重新加载数据
    然后执行完之后加一句GridView1.EditIndex = -1,如何再一次绑定数据
    还要你这样代码写了太乱了 一些公共的东西不能把它封装在一个方法吗?

    评论

报告相同问题?

悬赏问题

  • ¥15 Arduino红外遥控代码有问题
  • ¥15 数值计算离散正交多项式
  • ¥30 数值计算均差系数编程
  • ¥15 redis-full-check比较 两个集群的数据出错
  • ¥15 Matlab编程问题
  • ¥15 训练的多模态特征融合模型准确度很低怎么办
  • ¥15 kylin启动报错log4j类冲突
  • ¥15 超声波模块测距控制点灯,灯的闪烁很不稳定,经过调试发现测的距离偏大
  • ¥15 import arcpy出现importing _arcgisscripting 找不到相关程序
  • ¥15 onvif+openssl,vs2022编译openssl64