首 页 网络编程
网页制作 图形图象 操作系统 冲浪宝典
软件教学 认证考试

网络安全 网络办公 行业资讯 评测对比
您当前位置:站长天空 -> 认证考试-> Adobe认证
在vb中用dao实现数据库编程_visualbasic教程
作者:网友供稿 点击:0
推荐
西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!可在线rar解压,自动数据恢复设置虚拟目录等.免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金
站内搜索
文章页数:[1] 
DAO(DataAccessObject)全称为数据访问对象,它是数据库编程的重要方法之一。DAO的一种面向对象的界面接口,特色为它不是可视化的对象,使用它全部都要靠编码来完成,DAO是设计关系型数据库系统结构的对象类的集合。它提供了完成管理这样一个系统所需的全部操作的属性和方法,包括创建数据库,定义表、字段和索引,建立表间的关系,定位和查询数据库等工具。由于ADO(ActiveXDataObjectActiveX数据对象)的出现,DAO的使用已大大减少,但它无须使用ODBC(开放数据库连接)便可连接各个数据源,因而我们仍经常用经典的DAO。下面我向大家详细介绍如何使用DAO编程。

  DAO使用之前必须先引用。方法为打开VB6.0,从VB的"工程"菜单中,选择"引用"项,当"引用"对话框出现后,从库的列表中,选择"MicrosoftDAO3.51ObjectLibrary",单击"确定"。现在便可以使用DAO对象库提供的所有对象进行编程了。

  一、创建数据库:

  在DAO中用CreatDataBase方法可以根据用户需求动态的创建数据库。这一点在程序中是非常有用的。用户可以根据要求实时建立数据库。建立过程如下:  

  PrivateSubCom_creat_Click()

  OnErrorGoToErr100

  CreatDataBase"数据库名称.mdb",dbLangGeneral

  Msgbox"数据库建立完毕"

  ExitSub

  Err100:

  MsgBox"不能建立数据库!"&vbCrLf&vbCrLf&Err.Description,vbInformation

  EndSub

  这样,数据库便在当前默认的路径下建立了。

  二、创建表与字段:

  建立数据库后,则需要在该数据库中建立表,这要用到TableDef对象。先定义一个TableDef类型的对象,然后用TableDef集合中Append方法将之追加到数据库当中去。并且同时定义一个Field对象,用CreatFiele的方法创建一个Field对象,向表中添加字段。例如:

  

  PrivateSubCom_table_Click()

  OnErrorGoToErr100

  DimDefdbAsDataBase

  DimNewTableAsTableDef

  DimNewFieldAsField

  SetDefdb=Workspaces(0).OpenDatabase(App.path&"\数据库名称.mdb",0,False)

  SetNewTable=DefDataBase.CreateTableDef("表名")

  SetNewField=DefTable.CreateField("字段名",dbText,6)′创建一个字符型的字段,长度为6个字符

  DefTableFields.AppendNewField′字段追加

  DefDatabase.TableDefs.AppendNewTable′表追加

  Msgbox"表建立完毕"

  ExitSub

  Err100:

  MsgBox"对不起,不能建立表。请先再建表前建立数据库?",vbCritical

  EndSub

  一个数据库可能有十几个甚至几十个字段,一个表中有多少个字段,则要创建多少次并要追加到表中。每建立一个字段后都要用到字段追加命令,但是表追加只需在所有字段建立完成后用一条命令即可完成。   

  三、打开数据库:

  在VB中,对一个对象变量引用之前必须加以说明。DAO也是如此,必须先声明数据库变量,例如:DimdbaseAsDatabase。建立了数据库对象变量后,我们便可打开数据库了,在一般情况下都只是访问一个数据库,当打开数据库后再对数据库中的各个记录进行操作,这就要用到Recordset对象建立记录集。例如:  

  PrivateSubCommand_OpenDatabase_Click()

  DimdbaseasDatabase

  DimrsAsRecordset

  Setdbase=OpenDatabase(App.path&"\数据库名称.mdb")

  Setrs=dbase.OpenRecordset("select*from表名")

  EndSub

  这样,数据库中的记录便放到Recordset中,可以进行后续操作了。

  四、使用数据库:

  当打开数据库,建立Recordset记录集后,便可浏览、删除、添加、查找数据库中的内容。


  1)向前浏览

    PrivateSubcmd_previous_Click()

  rs.MovePrevious

  ifrs.BOF=Truethen

  rs.Movelast

  Endif

  fori=0to11

  label(i).caption=rs.Fields(i)&""

  next

  EndSub

  在字段赋值的末尾加上""可以避免许多不必要的错误,在数据库中,当一个字段为空的时候,它的值为Null,Null表示什么也没有。因此无法赋值,赋给变量时会出错。但我们加上""空格符时,便有效的避免了赋值错误,这个技巧非常的有用。

  2)向后浏览 

  PrivateSubcmd_next_Click()

  rs.MoveNext

  Ifrs.EOF=Truethen

  rs.MoveFirst

  Endif

  fori=0to11

  label(i).caption=rs.Fields(i)&""

  next

  EndSub

  3)删除记录

  PrivateSubcmd_del_Click()

  OnErrorGoTohandle

  Dimmsgasstring

  msg="是否要删除记录"&Chr$(10)

  msg=msg&label(0)′把删除记录的代号加入msg中

  IfMsgbox(msg,17,"删除记录")<>1ThenExitsub

  rs.delete

  rs.Movenext

  Ifrs.EOF=TrueThen

  rs.MovePrevious

  Endif

  fori=0to11

  label(i).caption=rs.Fields(i)&""

  next

  handle:

  MsgBox"该记录无法删除!!!"

  ExitSub

  EndSub

  4)添加记录

  向数据库中添加记录比较麻烦一点,大致分为三步:首先,用AddNew方法向数据库添加一个新的空白记录;其次,将要输入的数据分别赋到数据库的各个字段中;最后,用Updata的方法,把记录写到数据库中去。例如: 

  PrivateSubcmd_new_Click()

  rs.AddNew

  Fori=0to11

  rs.Fields(i)=TextBox(i).Text

  Next

  rs.Updata

  EndSub

  5)查找记录

  查找记录可以用Find方法,例如:  

  PrivateSubCmd_search_Click()

  Setrs=dbase.openRecordset("表名",dbopenDynaset)

  rs.findfirst"字段名="&Text.Text&""′Text.Text是输入的关键字

  ifrs.Nomatch=Truethen

  Msgbox"对不起,没有该记录"

  else

  Fori=0to11

  label(i).caption=rs.Fields(i)&""

  Next

  Endif

  rs.close

  EndSub

  以上只是大致介绍了DAO的一些最常用、最典型的用法,真正要熟练掌握它需要不懈的努力。当你很好的理解了DAO后,对学习新的RDO和ADO也有很大的帮助。并且DAO和ADO可以同时使用,DAO的缺陷在于查找功能不强,没有ADO方便,但动态创建数据库却远超ADO,因此有时二者结合更强大。我们相信DAO一定会帮你节约宝贵时间,为工作提供方便。->


文章整理:站长天空 网址:http://www.z6688.com/
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

文章页数:[1] 


放大字体显示 缩小字体显示 打印文章 推荐给朋友
热门文章
·Java开发工具配置 UltraEdit-JSP教程,Java技巧及代码
·遍历设备管理器的设备-.NET教程,评论及其它
·用正则表达式剔除文本中的HTML标记-ASP教程,正则表达式
·一个通用的DataGridTableStyle的做法-.NET教程,数据库应用
·java连接Oracle数据库-JSP教程,Java技巧及代码
·将XML存入关系数据库-JSP教程,数据库相关
·如何在Web页面上直接打开、编辑、创建Office文档-ASP教程,ASP应用
·asp之日期和时间函数示例-ASP教程,ASP应用
·ASP.Net Web Page深入探讨-ASP教程,ASP应用
·浅析Microsoft .net PetShop程序中的购物车和订单处理模块(Profile技术,异步MSMQ消息)-.NET教程,.NET Framework
最新文章
·fireworks 8绘制精致指南针图案_fireworks教程
·卸载多重引导系统中的windows vista操作系统_windows vista
·如何做到google adsense好收入的几点_网赚技巧
·百度主题推广和google adsense的综合比较_网赚技巧
·[新闻会客厅]孙雁:八零后的女闪客_站长访谈
·“流量交换型站点”访客黏度问题凸显_站长心得
·大唐社区站长经验谈社区运营_站长心得
·blog站点如何用rss搜索来推广_站长心得
·自我防护web站点和恶意链接的方法_站长心得
·网站投资你和我的20个自身检查(2)_站长心得
相关主题
  • 在vb中用outlook发电子邮件_visualbasic教程
  • 在vb中用api实现多媒体_visualbasic教程
  • 西部数码虚拟主机

    友情链接
    CNNIC 西部数码
    万网 自助建站
    虚拟主机 asp空间
    域名注册 域名
    域名申请 主页空间
    论坛空间 网站空间
    国际域名 虚拟空间
    空间租用 DDOS防火墙
    成都主机托管 四川主机托管
    主机租用 服务器租用
    网站目录 自助建站
    虚拟主机 网址大全
    软件下载
    自助链接
    虚拟主机资讯 特价虚拟主机
    版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
    关于我们:站长天空:专业提供最新的站长资讯、在线教程、虚拟主机权威评测、虚拟主机性能对比、网站制作教程,开发教程,站长工具。包括网页制作教程、冲浪宝典、编程参考、操作系统、软件教学、行业动态等。
    特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
    发表评论 打印  刷新     关闭