GridView1.DataKeys[e.RowIndex].Value.ToString() 索引超出范围问题

GridView1.DataKeys[e.RowIndex].Value.ToString() 索引超出范围问题

问题:GridView1.DataKeys[e.RowIndex].Value.ToString() 必须为非负值并小于集合大小。


异常信息:System.Web.HttpUnhandledException: 引发类型为   “System.Web.HttpUnhandledException”的异常。---> System.ArgumentOutOfRangeException: 索引超出范围。必须为非负值并小于集合大小。


报错位置:GridView1.DataKeys[e.RowIndex].Value.ToString()。


解决方法:在GridView列表属性的 DataKeyNames 项里添加所设为主键的字段名就可以。
步骤:
1、sql表中设置主键字段,如deptInId
2、在 .aspx设计界面选中GridView1,在属性栏中将DataKeyNames设置为主键字段名deptInId

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于C#和ASP.NET,GridView控件是一个非常常用的控件,用于显示和编辑数据。以下是一个简单的示例,演示如何使用GridView实现增删改查功能。 首先,在ASP.NET页面中添加一个GridView控件: ```html <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False"> <Columns> <asp:BoundField DataField="id" HeaderText="ID" /> <asp:BoundField DataField="name" HeaderText="Name" /> <asp:BoundField DataField="age" HeaderText="Age" /> <asp:CommandField ShowEditButton="True" ShowDeleteButton="True" /> </Columns> </asp:GridView> ``` 然后,在后台代码中,需要添加以下事件处理程序: ```csharp protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { BindData(); } } protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e) { GridView1.EditIndex = e.NewEditIndex; BindData(); } protected void GridView1_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e) { GridView1.EditIndex = -1; BindData(); } protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e) { string id = GridView1.DataKeys[e.RowIndex].Value.ToString(); string name = ((TextBox)GridView1.Rows[e.RowIndex].FindControl("txtName")).Text; string age = ((TextBox)GridView1.Rows[e.RowIndex].FindControl("txtAge")).Text; // TODO: 更新数据库中的数据 GridView1.EditIndex = -1; BindData(); } protected void GridView1_RowDeleting(object sender, GridViewDeleteEventArgs e) { string id = GridView1.DataKeys[e.RowIndex].Value.ToString(); // TODO: 从数据库中删除数据 BindData(); } protected void btnAdd_Click(object sender, EventArgs e) { string name = txtName.Text; string age = txtAge.Text; // TODO: 将数据插入到数据库中 BindData(); } private void BindData() { // TODO: 从数据库中获取数据,并绑定到GridView控件中 } ``` 在代码中,`BindData`方法用于从数据库中获取数据,并将其绑定到GridView控件中。`Page_Load`方法在页面首次加载时调用`BindData`方法。`GridView1_RowEditing`、`GridView1_RowCancelingEdit`、`GridView1_RowUpdating`和`GridView1_RowDeleting`方法分别处理编辑、取消编辑、更新和删除操作。`btnAdd_Click`方法用于新增数据。 以上示例并没有实现完整的增删改查功能,需要根据具体需求进行修改和完善。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值