欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > PPT文档下载  

    VBA的数据库编程.ppt

    • 资源ID:6522597       资源大小:1.17MB        全文页数:44页
    • 资源格式: PPT        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    VBA的数据库编程.ppt

    第10章,在开发Access数据库应用系统时,为了能开发出更实用、更有效的Access数据库应用程序,以便能快速、有效地管理好数据,还应当学习和掌握VBA的数据库编程方法。,VBA的数据库编程,第10章 VBA的数据库编程,本章主要内容,退出,10.1 数据库访问接口10.2 数据访问对象(DAO)10.3 ActiveX数据对象(ADO),10.1 数据库访问接口,为了在VBA程序代码中能方便地实现对数据库的数据访问功能,VBA语言提供有相应的通用的接口方式。VBA是通过 Microsoft Jet 数据库引擎工具来支持对数据库的访问。所谓数据库引擎实际上是一组动态链接库(DLL),当程序运行时被连接到 VBA 程序而实现对数据库的数据访问功能。数据库引擎是应用程序与物理数据库之间的桥梁,它以一种通用接口的方式,使各种类型物理数据库对用户而言都具有统一的形式和相同的数据访问与处理方法。,10.1 数据库访问接口(续),在VBA语言中,提供了如下三种基本的数据库访问接口:(1)开放数据库互连应用编程接口(简称ODBC API)。(2)数据访问对象(简称DAO)。(3)Active数据对象(简称ADO)。在VBA语言程序设计中,通过数据库引擎可以访问如下三种类型的数据库:(1)本地数据库,即是 Access 数据库。(2)外部数据库,即是所有的索引顺序访问方法(ISAM)数据库。(3)ODBC数据库,即是符合开放数据库连接(ODBC)标准的数据库,例如,Oracle、Microsoft SQL Server等。,10.2 数据访问对象(DAO),数据访问对象(DAO)是VBA语言提供的一种数据访问接口。包括数据库、表和查询的创建等功能,通过运行VBA程序代码可以灵活地控制数据访问的各种操作。当用户在Access模块设计中要使用DAO的访问对象时,首先应该增加一个对DAO库的引用。Access 2003的DAO引用库为DAO3.6,其引用设置方法为:先进入VBA编程环境,即打开VBE窗口,单击菜单栏中的“工具”,单击“工具”菜单中的“引用”项,弹出“引用”对话框,如图10-1所示,从“可使用的引用”的列表项中,选中“Microsoft DAO 3.6 Object Library”项,然后,单击“确定”按钮。,10.2.1 DAO模型结构,DAO 模型的分层结构图如图10-2所示。它包含了一个复杂的可编程数据关联对象的层次,其中 DBEngine对象处于最顶层,它是模型中惟一不被其他对象所包含的数据库引擎本身。层次低一层对象是,Errors和 Workspaces对象。层次再低一层对象如Errors对象的低一层对象是Error;Workspaces 对象的低一层对象是 Workspace。Databases 的低一层对象是 Database。Database 的低一层对象是 Containers、QueryDefs、RecordSets、Relations 和 TableDefs。TableDefs对象的低一层对象是 TableDef。同理如此类推,在此不作详列。其中对象名的尾字符为“s”的那些对象(如,Errors、Workspaces、Databases、TableDefs、Fields 等)是集合对象,集合对象下一层包含其成员对象。,10.2.2 DAO对象变量的声明和赋值,DAO 对象必须通过 VBA 程序代码来控制和操作。在代码中,必须设置对象变量,然后再通过对象变量使用其下的对象、或者对象的属性和方法。1对象变量的声明 同普通变量的声明一样,声明的关键字可以是 Dim、Private、Public 等。声明对象变量的语句格式:Dim 对象变量名 As 对象类型 例如:Dim wks As Workspace 声明wks为工作区对象变量 Dim dbs As Database 声明dbs为数据库对象变量,2对象变量的赋值,Dim 只是声明了对象变量的类型,对象变量的值必须通过 Set 赋值语句来赋值。Set赋值语句的格式:Set 对象变量名称=对象指定声明例如:Set wks=DBEngine.Workspaces(0)打开默认工作区(即0号工作区)Set dbs=wks.OpenDatabase(e:Access职工管理.mdb)打开数据库,例10-1,例10-1 通过 DAO 编程,显示当前打开的数据库的名称。Private Sub Cmd1_Click()Dim wks As Workspace 声明工作区对象变量 Dim dbs As Database 声明数据库对象变量 Set wks=DBEngine.Workspaces(0)打开默认工作区(即0号工作区)Set dbs=wks.Databases(0)打开当前数据库(即0号数据库)MsgBox dbs.Name Name 是 Database 对象变量的属性End Sub,例10-1(续),10.2.3 DAO对象的部分属性和方法,1Database 对象的常用属性和方法 Database 对象代表数据库。Database对象的常用属性如表10-2所示。Database对象的常用方法如表10-3所示。,表10-2 Database对象的常用属性,表10-3 Database对象的常用方法,2TableDef 对象的CreateField方法,使用 TableDef 对象的 CreateField 方法可创建表中的字段。使用 CreateField方 法的语句格式:Set fed=tbe.CreateField(name,type,size)其中:fed 是字段对象变量。tbe 是表对象变量。name是字段名。type 是字段的数据类型,要用英文字符表示,如 dbText 表示文本型,dbInteger 表示整型。size 表示字段大小。,3RecordSet 对象的常用属性和方法,RecordSet 对象代表一个表或查询中的所有记录。RecordSet 对象提供了对记录的添加、删除和修改等操作的支持。RecordSet 对象的常用属性如表10-4所示。RecordSet 对象的常用方法如表10-5所示。,表10-4 RecordSet对象的常用属性,表10-5 RecordSet 对象的常用方法的方法,10.2.4 利用DAO访问数据库,在 VBA 编程中,利用 DAO 实现对数据库访问时,要先创建对象变量,再通过对象方法和属性来进行操作。下面通过例子介绍利用 DAO 实现对数据库访问的一般语句和步骤:,例10-2(DAO数据库编程例),例10-2 编写一个使用DAO的名为 UseDaoUpdateAge 的子过程,通过调用该子过程来完成对“职工管理”数据库的“职工基本资料”表的年龄字段值都加1的操作。(假设“职工管理.mdb”数据库文件存放在E盘“E:Access”文件夹中,“职工基本资料”表中的“年龄”字段的数据类型是整型)。本例的窗体名称为“例10-2 使用DAO编程-年龄加1”。Cmd1 命令按钮的单击事件过程和 UseDaoUpdateAge 子过程的VBA程序代码如下:,例10-2 VBA代码,例10-3(DAO数据库编程例),例10-3 通过在VBA程序中使用DAO,在当前数据库中创建一个名为“用户表”的表。“用户表”的表结构如表10-6所示。该表的主键是“用户ID”字段。本例的窗体名是“例10-3 用 DAO 创建数据表”,窗体中的命令按钮名称是Cmd1。,例10-3VBA 代码,例10-4(DAO数据库编程例),例10-4 通过在VBA程序中使用DAO,实现往当前数据库中的“用户表”添加新记录。本例的窗体名是“例10-4 用DAO往用户表添加记录”,如图10-3所示。,例10-4VBA 代码,10.3 ActiveX数据对象(ADO),ActiveX数据对象(ActiveX Data Objects,简称ADO)是基于组件的数据库编程接口,它可以对来自多种数据提供者的数据进行读取和写入操作。在 Access 模块设计时要使用 ADO 的各个访问对象,也应该增加对 ADO 库的引用。Access 2003 的 ADO 引用库为 ADO2.1,其引用设置方式为:先进入 VBA 编程环境VBE,单击菜单栏中的“工具”,单击选择“工具”菜单中的“引用”项,弹出“引用”对话框,从“可使用的引用”列表框选择项中选中“Microsoft ActiveX Data Objects 2.1 Library”并按“确定”按钮即可。,10.3.1 ADO模型结构,ADO对象模型图如图10-4所示,它提供一系列数据对象供使用。不过,ADO 接口与 DAO不同,ADO对象不须派生,大多数对象都可以直接创建(Field 和 Error 除外),没有对象的分级结构。使用时,只需在程序中创建对象变量,并通过对象变量来调用访问对象方法、设置访问对象属性,这样就实现对数据库的各项访问操作。ADO 只需要九个对象和四个集合(对象)就能提供其整个功能。,ADO模型结构图,表10-7 ADO对象说明,10.3.2 ADO对象变量的声明,ADO 对象必须通过 VBA 程序代码来控制和操作。在代码中,必须设置对象变量,然后再通过对象变量使用其下的对象、或者对象的属性和方法。声明对象变量的语句格式:Dim 对象变量名称 As ADODB.对象类型 例如:Dim con As New ADODB.Connection 声明一个连接对象变量Dim res As New ADODB.RecordSet 声明一个记录集对象变量 注意,ADODB 是 ADO 类型库的短名称,用于识别与DAO中同名的对象。例如,DAO中有 RecordSet 对象,ADO 中也有 RecordSet对象,为了能够区分开来,在 ADO 中声明RecordSet 类型对象变量时,用上 ADODB.RecordSet。总之,在ADO中声明对象变量时,一般都要用上“ADODB.”前缀。,10.3.3 ADO对象的部分属性和方法,1Connection 对象的常用方法(1)Open方法通过使用Connection 对象的Open方法来建立与数据源的连接。Open方法的语句格式:Dim 连接对象变量名 As New ADODB.Connection连接对象变量名.Open ConnectionString,UserID,Password,OpenOptions 例如,创建与罗斯文示例数据库“Northwind.mdb”连接的语句:Dim cnn As New ADODB.Connection 声明一个连接对象变量 cnncnn.Open Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:Program FilesMicrosoft OfficeOFFICE11SAMPLES Northwind.mdb,(2)Close方法 通过使用 Connection 对象的 Close 方法来关闭与数据源的连接。Close方法的语句格式:连接对象变量名.Close 注意,该语句可以关闭Connection 对象,断开应用程序与数据源的连接。但是Connection 仍在内存中,释放 Connection 对象变量的方法是使用下面语句格式的语句:释放连接对象变量的语句格式:Set连接对象变量名=nothing 例如,关闭与“罗斯文示例数据库.mdb”连接的语句:cnn.CloseSet cnn=nothing,(3)如果指定的数据源就是当前已经打开的数据库,则必须通过 CurrentProject 对象的Connection属性来取得连接。语句格式:Dim 连接对象变量名 As New ADODB.ConnectionSet 连接对象变量名=CurrentProject.Connection 例如:创建与当前已经打开的数据库的连接:Dim cnn As New ADODB.Connection Set cnn=CurrentProject.Connection,2RecordSet 对象的常用属性和方法,建立 Recordset 对象的语句格式:Dim 记录集对象变量名 As ADODB.Recordset Set 记录集对象变量名=New ADODB.Recordset RecordSet 对象的常用属性如表10-8所示。RecordSet对象的常用方法如表10-9所示。,表10-8 RecordSet对象的常用属性,表10-9 RecordSet对象的常用方法,3Command 对象的常用属性和方法,(1)建立 Command 对象 建立 Command 对象的语句格式:Dim 对象变量名 As ADODB.Command Set 对象变量名=New ADODB.Command(2)Command 对象的常用属性如表10-10所示。(3)Command对象的常用方法如表10-11所示。,表10-10 Command对象的常用属性,表10-11 Command对象的常用方法,10.3.4 利用ADO访问数据库,在VBA编程中,利用ADO实现对数据库访问时,要先创建对象变量,再通过对象方法和属性来进行操作。注意,在 Access 的 VBA 语言中,为 ADO 提供了类似 DAO 的数据库打开快捷方式,即CurrentProject.Connection,它指向一个默认的ADODB.Connection 对象,该对象与当前数据库的Jet OLE DB服务提供者一起工作。不像CurrentDB()是可选的,用户必须使用CurrentProject.Connection 作为当前打开数据库的 ADODB.Connection 对象。,例10-5(ADO数据库编程例子),例10-5 编写一个使用 ADO 的名为UseAdoUpdateAge 的子过程,通过调用该子过程来完成对“职工管理”数据库的“职工基本资料”表的年龄字段值都加1的操作。(假设“职工管理.mdb”数据库文件存放在E盘“E:Access”文件夹中,“职工基本资料”表中的“年龄”字段的数据类型是整型)。本例的窗体名称为“例10-5 使用ADO编程-年龄加1”。Cmd1 命令按钮的单击事件过程和 UseAdoUpdateAge 子过程的 VBA 程序代码如下:,例10-6 VBA代码,

    注意事项

    本文(VBA的数据库编程.ppt)为本站会员(牧羊曲112)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开