vs2008的asp.net中GridView控件绑定数据库后更新,删除出错! 20
问题1:vs2008的asp.net中GridView控件绑定数据库后GridView1_RowEidting事件代码:GridView1.EditIndex=(int)...
问题1:vs2008的asp.net中GridView控件绑定数据库后
GridView1_RowEidting事件代码:
GridView1.EditIndex = (int)e.NewEditIndex;
databind();
GridView1_RowCancelingEdit事件代码:
GridView1.EditIndex = -1;
databind();
GridView1_RowUpdating事件代码:
string str = ((TextBox)GridView1.Rows[e.RowIndex].Cells[1].Controls[0]).text;
......
......
databind();
可以成功运行!而
string str = GridView1.DataKeys[e.RowIndex][0].toString();
......
......
databind();
不能成功运行,报错index超出索引范围!必须为非负值并小于集合大小!
GridView1_RowDeleting事件代码:
string str=GridView1.DataKeys[e.RowIndex][0].ToString();
或
string str = ((TextBox)GridView1.Rows[e.RowIndex].Cells[1].Controls[0]).text;
......
......
databind();
都不能运行!报错index超出索引范围!必须为非负值并小于集合大小!
请问报错的index是哪里的序号?为什么前者((TextBox)GridView1.Rows[e.RowIndex].Cells[1].Controls[0]).text可以,而后者2种都不可以运行?
应该怎么修改?! 展开
GridView1_RowEidting事件代码:
GridView1.EditIndex = (int)e.NewEditIndex;
databind();
GridView1_RowCancelingEdit事件代码:
GridView1.EditIndex = -1;
databind();
GridView1_RowUpdating事件代码:
string str = ((TextBox)GridView1.Rows[e.RowIndex].Cells[1].Controls[0]).text;
......
......
databind();
可以成功运行!而
string str = GridView1.DataKeys[e.RowIndex][0].toString();
......
......
databind();
不能成功运行,报错index超出索引范围!必须为非负值并小于集合大小!
GridView1_RowDeleting事件代码:
string str=GridView1.DataKeys[e.RowIndex][0].ToString();
或
string str = ((TextBox)GridView1.Rows[e.RowIndex].Cells[1].Controls[0]).text;
......
......
databind();
都不能运行!报错index超出索引范围!必须为非负值并小于集合大小!
请问报错的index是哪里的序号?为什么前者((TextBox)GridView1.Rows[e.RowIndex].Cells[1].Controls[0]).text可以,而后者2种都不可以运行?
应该怎么修改?! 展开
4个回答
展开全部
很有可能是你的sql语句的问题
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
点击GridVew,选择编辑列,看看你的主键是否是在正确位置上。。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
处理下 selectedIndexChanging 事件
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询