网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > ASP.NET技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.ASP.NET通过DSO访问分析服务器的.
..NET环境下几种不同的邮件发送解.
.如何获取当前程序文件的路径 Cur.
.我的aspx为什么无法显示中文.
.解析Asp.net中资源本地化的实现.
.自定义控件中使用枚举类型的属性.
.ASP.NET页面下载程序.
.ASP.NET2.0下利用javascript实现.
.精通ASP.NET中弹出窗口技术.
.收藏一段小的.net下的验证码片段.
.有趣的lucene.net索引.
.用GZip压缩和解压.
.Asp.net(C#)多文件上传.
.ASP.NET热点问题解答14个.
.WEB页面多语言支持解决方案.
.在ASP.NET应用中插入flash动画.
.图片地址防盗链,通过IHttpHandle.
.ASP.net组件编程中的两种事件编写.
.ASP.NET常用的26个优化性能方法.
.ASP.NET实现下拉框二级联动组件.

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

发表日期:2005-5-23


当把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)

上一篇:在ASP.NET中使用SQL的IN操作 人气:9839
下一篇:asp.net开发web项目-vss集成环境配置 人气:15865
浏览全部asp.net的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐