VisualBasic程序设计项目化教程项目14ADO数据库访问技术的应用课件.ppt
《VisualBasic程序设计项目化教程项目14ADO数据库访问技术的应用课件.ppt》由会员分享,可在线阅读,更多相关《VisualBasic程序设计项目化教程项目14ADO数据库访问技术的应用课件.ppt(57页珍藏版)》请在文库网上搜索。
1、Visual Basic Visual Basic 程序设计程序设计项目化教程项目化教程主编 管小清 郭贺彬Visual Basic 程序设计项目化教程主编 管小项目十四:ADO数据库访问技术的应用n项目功能描述:n本项目主要是了解ADO的主要功能与特性,ADO对象模型简介及ADO的编程模型。掌握ADODC控件的主要属性、常用方法及常用事件。掌握数据绑定控件的主要属性、常用方法及常用事件。掌握在Visual Basic中使用ADO对象,进行非编程式访问数据库和编程式访问数据库项目十四:ADO数据库访问技术的应用项目功能描述:项目十四:ADO数据库访问技术的应用n项目主要知识点:n1关于ADOn
2、2ADODC控件n3数据绑定控件n4在Visual Basic中使用ADO对象n项目实施步骤:n阅读基础知识n实例操作n完成思考与练习题项目十四:ADO数据库访问技术的应用项目主要知识点:14.1 基础知识概述n14.1.1关于ADOn1.ADO主要功能与特性nADO(ActiveX Data Object, Active 数据对象)是基于OLE DB技术而设计的。是Microsoft提供的一种面向对象,与语言无关的基于应用程序层的数据访问接口。它是DAO/RDO的后继产物。它主要特性:易于使用、可以访问多种数据源、访问速度快且效率高、易于Web应用、技术编程接口丰富、低内存支出和占用磁盘空间
3、较少。ADO访问数据是通过OLE DB来实现的,OLE DB不仅能够以SQL Server、Oracle、Access等数据库文件为访问对象,还可对Excel表格、文本文件、图形文件、电子邮件等各种各样的数据通过统一的接口进行存取。ADO与OLE DB的关系如图14-1所示:14.1 基础知识概述14.1.1关于ADO14.1 基础知识概述图 14-1 ADO与OLE DB的关系图 14-1 ADO与OLE DB的关系14.1 基础知识概述图 14-1 ADO与OLE DB14.1 基础知识概述n2ADO对象模型nADO集中了DAO和RDO的优点,且不像DAO和RDO那样依赖于对象层次。ADO
4、对象模型定义了一个可编程的分层对象集合,ADO模型主要由七个对象成员Connection(连接)、Command(命令)、RecordSet(记录集)、Error(错误)、Parameter(参数)、Field(字段)和Property(属性)以及四个集合对象Errors、Parameters、Fields、Properties所组成。每个 Connection、Command、Recordset和Field对象都有Properties集合。n它们之间的关系如图14-2所示: 网图 14-2 ADO对象模型关系图 14-2 ADO对象模型关系14.1 基础知识概述2ADO对象模型图 14-2
5、A14.1 基础知识概述n(1) Connection 对象n用于管理与数据库的连接, 通过连接可从应用程序访问数据源,包括打开和关闭连接以及运行SQL命令等,它保存诸如指针类型、连接字符串、查询超时、连接超时和缺省数据库这样的连接信息。它包含了关于目标数据库数据提供程序的相关信息。n(2)Command 对象n包含关于某个命令,例如查询字符串、参数定义等的信息。n(3)Recordset对象n用来存储数据操作返回的记录集。Recordset对象只代表一个记录集,这个记录集可以是一个数据库中的表,或者是Command对象的执行结果返回的记录集。在ADO对象模型中,是在行中检查和修改数据的最主要
6、的方法,所有对数据的操作几乎都是在Recordset对象中完成的。Recordset对象用于指定行、移动行、添加、更改、删除记录。14.1 基础知识概述(1) Connection 对象14.1 基础知识概述n(4)Field 对象nField 对象对应于数据库表的字段或SQL查询语句Select关键字之后跟随着的域,宽限包含记录集中数据的某单个列的信息。n(5) Error对象n包含数据提供程序出错时的扩展信息。n(6) Parameter 对象nParameter 对象用于管理基于参数化查询或存储过程的Command对象相关联的某个参数或自变量的信息,这类Command对象有一个包含其所有
7、Parameter 对象的 Parameters 集合。n(7) Property对象n包含某个 ADO 对象的提供程序定义的特征。n掌握其中的Command、Connection、Recordset对象就可以实现基本的数据库操作。14.1 基础知识概述(4)Field 对象14.1.2 ADO的编程模型nADO编程模型描述了使用ADO对象进行编程所必须的几个重要步骤:n1.连接数据源n利用Connection对象的Open方法可以创建一个数据源的连接。n 语法:Connection对象.Open ConnectionString, UserID, PassWord, OpenOptionsn
8、其中:Connection对象为定义的Connection对象的实例;nConnectionString为可选项,包含了连接的数据库的信息;n UserID 可选项,包含建立连接的用户名;n PassWord为可选项,包含建立连接的用户密码;14.1.2 ADO的编程模型ADO编程模型描述了使用ADO14.1.2 ADO的编程模型n2.打开记录集对象n(1)方法一:n语法:Recordset.Open Source, ActiveConnection, CursorType, LockType, Optionsn 其中:Recordset为所定义的记录集对象的实例。n Source可选项,指明
9、了所打开的记录源信息。 ActiveConnection可选项,合法的已打开的Connection对象的变量名或者是包含ConnectionString参数的字符串。n CursorType可选项,确定打开记录集对象使用的指针类型。n LockType可选项, 确定打开记录集对象使用的锁定类型。14.1.2 ADO的编程模型2.打开记录集对象14.1.2 ADO的编程模型n(2)方法二:n语法:Set Recordset=Connection.Execute_n (CommandText,RecordsAffected,Options)n 其中: CommandText 一个字符串,返回要执行
10、的SQL命令、表名、存储过程或指定文本。n RecordsAffected 可选项,Long类型值,返回操作影响的记录数。nOptions 可选项,Long类型值,指明如何处理CommandText参数。n 打开Recordset对象之后,我们就可以使用它的addnew、delete、update、movenext、find等方法了。 14.1.2 ADO的编程模型(2)方法二:14.1.2 ADO的编程模型n3.添加记录n添加新记录的AddNew方法n语法:Recordset.AddNew Fields, Valuesn 其中:Recordset为记录集对象实例n Fields为一个字段名,
11、或者是一个字段数组。n Values为给要加信息的字段赋的值,如果Fileds为一个字段名,那么Values应为一个单个的数值。假如Fileds为一个字段数组,那么Values必须也为一个个数,类型与Fields相同的数组。n 使用AddNew方法为记录集添加新的记录后,应使用UpDate将所添加的的数据存储在数据库中。14.1.2 ADO的编程模型3.添加记录14.1.2 ADO的编程模型n4.修改记录集n 用SQL语句将要修改的字段的一个数据找出来重新赋值。n5.删除记录的Delete方法n 语法:Recordset.Delete AffectRecordsn其中:AffectRecord
12、s参数是确定Delete方法作用的方式的。n它的取值如下: adAffectCurrent 只删除当前的记录。n adAffectGroup 删除符合Filter属性设置的那些记录。为了一次能删除一组数据,应设置Filter属性。n6.查询记录n(1)方法一:n使用连接对象的Execute方法执行SQL命令,返回查询记录集。n(2)方法二:n 使用Command对象的Execute方法执行CommandText属性中设置的SQL命令,返回查询记录集。14.1.2 ADO的编程模型4.修改记录集14.1.2 ADO的编程模型n7.断开连接n 在应用程序结束之前,应该释放分配给ADO对象的资源,操
13、作系统回收这些资源并可以再分配给其他应用程序.n 使用的方法为:Close方法。n语法: ADO对象.Close 14.1.2 ADO的编程模型7.断开连接 14.2 ADODC控件 n14.2.1 ADODC控件n在VB中,使用ADO访问数据库主要有两种方式,一种是使用ADO数据控件,通过对控件的绑定来访问数据库中的数据,即非编程访问方式;另一种是使用ADO对象模型,通过定义对象和编写代码来实现对数据的访问,即编程访问方式,以下我们先介绍使用ADODC控件对数据库进行访问。 n1ADODC控件几个重要的与数据库有关的属性,如表14-1所示: 14.2 ADODC控件 14.2.1 ADODC
14、控件 14.2 ADODC控件 n表 14-1 ADO控件属性CommandType指示命令类型。取值为:1 adCmdText SQL 语句2 adCmdTable 表4 adCmdStoredProc存储过程8 adCmdUnknown 其他类型ConnectionString支持连接字符串的OLEDB提供程序(打开属性页-通用)。ConnectionTimeou在中止前等待打开连接的时间量(单位秒)。CursorLocation决定时使用服务器端游标还是客户端游标(使用哪个游标引擎) 。取值为:2 adUseServer3 adUseClientCursorType设置用于下一级Reco
15、rdset的游标类型。取值为:1 adOpenKeyset2 adOpenDynamic3 adOpenStaticPassword密码-支持密码的OLEDB提供程序。(打开属性页-身份验证)RecordSourceRecordset源(adCommandText=SQL或者其它命令语法,adCommandTable=表名称。) (打开属性页-记录源)UserName用户名称-支持用户名称的OLEDB提供程序 14.2 ADODC控件 表 14-1 ADO控件属性 14.2 ADODC控件 n2ADODC控件常用的方法n(1)Refresh方法。n该方法用于刷新与ADODC控件连接的记录集数据
16、。n(2)UpDateRecord方法n通过此方法可以将数据绑定控件上的当前内容写入到数据库。n(3)Close方法nClose方法主要用于关闭打开的对象及相关对象。n3ADODC控件的事件nADODC控件的事件分为两种类型即:Will事件和Complete事件。其中Will事件是在操作开始之前调用,这时可能检查或修改操作参数,并且可以决定是取消操作还是允许完成操作。而Complete事件是在操作完成之后调用。 14.2 ADODC控件 2ADODC控件常用的方法 14.2 ADODC控件 n(1)WillMove事件nWillMove事件在执行更改Recordset中的当前记录操作之前调用。
17、而MoveComplete事件则是在执行更改Recordset中的当前记录操作之后被调用。执行Recordset.Open、Recordset.MoveNext、Recordset.Move、Recordset.MoveLast、Recordset.MoveFirst、Recordset.MovePrevious、Recordset.Bookmark、Recordset.AddNew、Recordset.Delete、Recordset.Requery等方法时触发。 14.2 ADODC控件 (1)WillMove事件 14.2 ADODC控件 n(2)WillChangField事件和Fie
18、ldChangComplete事件n WillChangeField 在Recordset对象中Field属性值更改之前调用。而FieldChangeComplete 在Recordset对象中Field属性值更改之后调用。 执行Recordset.Update、Recordset.Delete、Recordset.CancelUpdate、Recordset.UpdateBatch、Recordset.CancelBatch 等方法时触发。 n(3)WillChangRecordSet事件n WillChangRecordSet发生在对Recordset对象进行操作之前,而nRecordSe
19、tChangComplete发生对Recordset对象进行操作之后。 14.2 ADODC控件 (2)WillChangFiel14.2.2 数据绑定控件n1数据绑定简述nADODC控件只能连接数据库,产生记录集。但不能显示记录集中的数据,要显示记录集中的数据必须通过能与它绑定的控件来实现。 数据库记录集数据绑定图 14-3 数据绑定与数据库和记录集关系图 14-3 数据绑定与数据库和记录集关系14.2.2 数据绑定控件1数据绑定简述数据库记录集数据绑14.2.2 数据绑定控件n数据绑定控件n具有DataSource、DataField属性的控件均可作为绑定控件n(2)常用绑定控件nComB
20、ox,Label,TextBox等控件是较为常用的数据绑定控件。14.2.2 数据绑定控件数据绑定控件14.2.2 数据绑定控件n(3)专门与ADO控件绑定的ActiveX控件nDataList 数据列表控件n我们在下一节将专门介绍ADO控件与DataList控件结合显示数据。nDataGrid 数据网格控件n我们在下一节将专门介绍ADO控件与DataGrid控件结合显示数据。nDataCombo 数据组合控件n(4)高级数据绑定控件nMi crosoft Hierarchical FlexGfid 分层式网格控件nMicrosoft Chart 图表控件n以上控件中数据网格控件和图表控件可以
21、绑定到整个记录集,而其他控件只能绑定到记录集的某一个字段。14.2.2 数据绑定控件(3)专门与ADO控件绑定的Act14.2.2 数据绑定控件n2数据绑定方法n(1)添加控件n首先添加ADODC控件及绑定控件添加到窗体上。n(2)设置ADODC控件属性n设置ADODC控件的ConnectionString,RecordSource,Password,UserName属性,连接数据库。n(3)设置绑定控件的DataSource属性n将绑定控件的DataSource属性设为ADODC控件的名称。n(4)设置绑定控件的DateField属性n将绑定控件的DateField属性设为要显示的字段名称。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- VisualBasic 程序设计 项目 教程 14 ADO 数据库 访问 技术 应用 课件