转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 软件开发 >> VB.NET程序 >> 正文
[初学VB.NET]使用心得随记(一) : 关于数据的绑定及更新         ★★★★

[初学VB.NET]使用心得随记(一) : 关于数据的绑定及更新

作者:闵涛 文章来源:闵涛的学习笔记 点击数:1614 更新时间:2009/4/23 19:01:19
成的命令。
     OleDbDataAdapter
不会自动生成为了使对 DataSet 所作的更改和相关联的数据源协调起来所必须的 SQL 语句。但是,如果设置了 OleDbDataAdapterSelectCommand 属性,那么就可以创建 OleDbCommandBuilder 对象,来自动生成 SQL 语句以更新单表。然后,OleDbCommandBuilder 将生成其他任何未设置的 SQL 语句。
     每当设置了 DataAdapter 属性,OleDbCommandBuilder 就将其本身注册为 RowUpdating 事件的侦听器。一次只能将一个 OleDbDataAdapter 与一个 OleDbCommandBuilder 对象(或相反)互相关联。
      为了生成 INSERT、UPDATE 或 DELETE 语句,OleDbCommandBuilder 会自动使用 SelectCommand 属性来检索所需的元数据集。如果在检索元数据后(例如在第一次更新后)更改 SelectCommand,则应调用 RefreshSchema 方法来更新元数据。
      OleDbCommandBuilder
还使用由 SelectCommand 引用的
ConnectionCommandTimeoutTransaction 属性。如果修改了任何这些属性或者替换了 SelectCommand 本身,用户则应调用 RefreshSchema。否则,InsertCommandUpdateCommandDeleteCommand 属性都保留它们以前的值。
     如果调用 Dispose,则会解除 OleDbCommandBuilderOleDbDataAdapter 的关联,并且不再使用所生成的命令。



3、数据更新中出现的问题:
      问题:更新数据后,出现一个奇怪的问题:datagrid中更新的数据出现相同的两条记录
      解决方法:
        a)、更新记录后,清除dataset,再重新填充
               dataset1.Tables("表1").Clear()
              adapter1.Fill(dataset1, "表1")
       b)、  另一种方法为:在form1的load 过程(Frm1_Load)中定义dataset1.Tables("表1")的主键:
 
        dataset1.Tables("表1").PrimaryKey = New DataColumn() {dataset1.Tables("表1").Columns("主键字段")}
       ''''如是自动编号,可以加入以下内容: 
       dataset1.Tables("表1").Columns("主键字段").AutoIncrement = True
        dataset1.Tables("表1").Columns("主键字段").AutoIncrementSeed = 1
        dataset1.Tables("表1").Columns("主键字段").AutoIncrementStep = 1

         ''''要确保列中的值唯一,可将列值设置为在表中添加新行时自动递增。
        ''''要创建自动递增的 DataColumn,可将列的 AutoIncrement 属性设置为 true。
        ''''然后,DataColumn 将从 AutoIncrementSeed 属性中定义的值开始,并且,随着各行的添加,
        ''''AutoIncrement 列的值将按列的 AutoIncrementStep 属性中具有的值增加。
        ''''对于 AutoIncrement 列,建议将 DataColumn 的 ReadOnly 属性设置为 true

4、执行删除操作时出现的问题:
   问题:   
       开始我参照自动生成的datafrom中代码,用:   Me.BindingContext(dataset1, "表1").RemoveAt(Me.BindingContext(dataset1, "表1").Position)   发现记录指针乱序,根本不是删除我指定的当前记录
  解决方法:
     更改为 引用datagrid的CurrentRowIndex,便可删除当前记录,休码如下:
      Me.BindingContext(dataset1, "表1").RemoveAt(Me.DataGrid1.CurrentRowIndex())
======================================================================
以上为我初学vb.net中所遇到的问题及解决方法(在XP上运行通过),如有不当之处,请各位指出,谢谢!
并在此感谢论坛中解答我问题的各位!!!

上一页  [1] [2] 


[Sql Server]Sql精妙语句--各种求值函数  [网页制作]网页表格之---多个表格纵向排列
[网页制作]JavaScript另类用法--读取和写入cookie  [网页制作]号称非常安全的上网工具---360安全浏览器介绍
[办公软件]信息技术教学篇---Word工具栏的显示、隐藏及四种菜…  [操作系统]开始菜单---运行命令大总结
[操作系统]网络转载---64位操作系统与32位的区别  [操作系统]ldap:///(没有响应)Windows无法访问指定设备、路径…
[网络技术]安全篇---交换机设置方法介绍  [聊天工具]Real10 & Xpdf installation on Linux Box
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · C语言系列  · VB.NET程序
    · JAVA开发  · Delphi程序
    · 脚本语言
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台