首页 | 互联网 | IT动态 | IT培训 | Cisco | Windows | Linux | Java | .Net | Oracle | 软件测试 | C/C++ | 嵌入式开发 | 存储世界 | 服务器
网络设备 | IDC | 安全 | 求职招聘 | 数字网校 | 笔记本电脑 | 北大青鸟 | 技术专题 | 电子书下载 | 教学视频 | 源码下载 | 搜索 | 博客 | 论坛
中国IT实验室Dotnet频道
中国IT教育
Google
首页 ASP.NET  C#  XML/WebService ADO.NET VC.NET VB.NET .NET 资讯动态 专题 RSS订阅 讨论 下载
您现在的位置: 中国IT实验室 >> Dotnet >> ASP.NET >> 正文

datagrid与DataSet结合使用中出现的索引问题

  当把DataSet 绑定到Datagrid控件,并利用DataAdapter对象修改数据库 
   
  如:
   dim adp as new OleDbDataAdapter(stradp,conn)
   dim ocb as new OleDbCommandBuilder(adp)
   adp.DeleteCommand = ocb.GetDeleteCommand()
   adp.Update(ds,"Orders") 
     
  执行删除操作时,如我们加入这样一个方法:
  sub mydatagrid_delete(sender as object, e as datagridcommandeventargs)
   dim dt as new DataTable()
   dt = ds.Tables("Orders")
   dim dr as DataRow
   dr = dt.Rows(E.Item.ItemIndex)
   dr.delete
   'dr.AcceptChanges '曾经尝试使用彻底删除,发现adp自动更新回数据库时,无法自动生成相应的sql语句 
   
  '解决删除当前页最后一项时出现的页索引异常 
 
   dim lastEditPage as integer = mydatagrid.currentPageIndex
   If (mydatagrid.pageCount - mydatagrid.currentPageIndex) = 1 and mydatagrid.Items.Count = 1 Then
   If mydatagrid.pageCount > 1 Then
   lastEditPage = LastEditPage - 1
   Else
   lastEditPage = 0
   End If
  
   End If
   mydatagrid.currentPageIndex = lastEditPage   
   session("orderList") = ds
   mydatagrid.edititemindex = -1
   mydatagrid.datasource = ds.tables("Orders")
   mydatagrid.databind()
  end sub 
   
  当由第一个开始逐个删除时出现了异常,发现在删除第二时,删不掉,即原来的dr(2)没有自动变为dr(1)。如果我们使用dr.delete dr.acceptChanges则可以自动变化,但是上面说明了,则无法使用自动更新回到数据库。我们必须获得删除时的实际索引,所以就用了一个本方法,在当前的ds中另外建了一个Table,保持同步删除,但是在Table的id列中,保存实际的索引值,具体代码如下: 
   
  解决dr索引的一个办法:
  
   dim orderTable as new DataTable() '建一个临时表用来保存索引,保持同步删除
   dim theNewRow as DataRow
   dim dc as DataColumn
  
   orderTable.TableName = "orderId"
   ds.Tables.add(orderTable)
   dc = new DataColumn()
   dc.ColumnName = "id"
   orderTable.columns.add(dc)
  
   dim dcKey() as DataColumn = {orderTable.Columns("id")}
   orderTable.primaryKey = dcKey
  
   dim i as integer
   For i = 0 to (ds.Tables("Users").Rows.Count - 1)
   theNewRow = orderTable.NewRow()
   theNewRow("id") = i.toString()
   orderTable.Rows.add(theNewRow)
   Next 
   
  上述删除功能中加的代码,替换 dr = dt.Rows(e.Item.ItemIndex):
  
   dim drOrder as DataRow
   drOrder = ds.Tables("orderId").Rows(E.Item.ItemIndex)
   dim currentOrder as integer = CInt(drOrder("id")) + mydatagrid.currentPageIndex * mydatagrid.PageSize
   dr = dt.Rows(currentOrder)
   drOrder.delete 
   
  如果有更新功能,则替换dr = dt.Rows(e.Item.ItemIndex):
  
   dim drOrder as DataRow
   drOrder = ds.Tables("orderId").Rows(E.Item.ItemIndex)
   dim currentOrder as integer = CInt(drOrder("id")) + mydatagrid.currentPageIndex * mydatagrid.PageSize
   dr = dt.Rows(currentOrder) 
   
   
  

【责编:yuan】

中国IT教育

相关产品和培训
文章评论
 友情推荐链接
 认证培训
 专题推荐

 ·开源软件测试工具学习专题
 ·JSP Web开发 入门基础到高手进阶教程…
 ·JavaFX—是Java桌面的新希望么?
 ·安全至上 .NET开发安全策略…
 ·测试用例设计之道-测试用例学习专题
 ·面向Java开发人员的Scala指南
 ·Java设计模式之实例详解
 ·Oracle数据库11g 面向DBA和开发人员的重要新特性…
 ·桌面应用软件编程 J2SE技术详解…
 ·我“炫”我精彩-------WPF开发教程
 今日更新
 社区讨论
 博客论点
 频道精选
 Dotnet频道相关导航