GridView删除数据时索引超出范围的解决方法

  今天用GridView操作数据时,总是提示

索引超出范围。必须为非负值并小于集合大小。
参数名: index

说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。 

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

上网查了下解决方法,发现网上下面的答到了重点:

try:首先设置一个GridView 一个主键 对应于你数据库表的主键 

GridView1.DataSource = myds; 
GridView1.DataKeyNames = new string[] { "id" };//主键 
GridView1.DataBind(); 
sqlcon.Close(); 

然后写SQL语句:select 字段A,字段B where id=‘"+ GridView1.DataKeys[e.RowIndex].Value.ToString() + "‘";

而我的错误原因就是因为我没有设置主键,也就是DataKeyNames。
        

    好大的错误,搞了很长时间才整明白。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值