




已阅读5页,还剩7页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
VB中数据库的连接方法目前,绝大多数的数据库参考书都介绍了ODBC的手工配置方法,或者介绍了如何在代码中进行ODBC配置。但这两种方法都有一定的局限性: 不是当程序最终完成并分发到用户手中后,还需要为用户配置ODBC,显得既麻烦又不符合专业软件的要求;就是得编写复杂的更改操作系统注册表文件的程序,十分烦琐。本文从ADO(ActiveX Data Objects)入手,介绍无需配置数据源的几种常用大型数据库连接方法。 本文所述的无“数据源”连接,意义不是不需要数据源,否则连接无从谈起,而是不需要配置注册数据源所进行的连接。ODBC(Open DataBase Connectivity,开放式数据库连接)是用于连接不同数据源的标准编程语言接口。许多文章中介绍,在实现ODBC时,必须首先配置ODBC环境,进行数据源的注册,然后才能在对数据库编程时,对数据源进行连接、访问和操作,并提供了用PB或VB等语言工具实现数据源注册的具体方法。这些方法不但复杂烦琐,而且由于参数内容不一,配置时令人感觉无所适从,不宜把握。 走近ADO ADO是微软提供的数据库访问技术。它被设计用来同新的数据访问层OLE DB Provider一起协同工作,以提供通用数据访问(Universal Data Access)能力。OLE DB是一个底层的数据访问接口,用它可以访问各种数据源,包括传统的关系型数据库、电子邮件系统及自定义的商业对象等。 ADO提供了一个熟悉的、高层的对OLE DB的Automation封装接口。对那些熟悉RDO的程序员来说,可以把OLE DB看作ODBC驱动程序,如同RDO对象是ODBC驱动程序接口一样,ADO对象是OLE DB的接口。同样,像不同的数据库系统需要它们自己的ODBC驱动程序一样,不同的数据源也要求它们自己的OLE DB提供者(OLE DB provider)。目前,虽然OLE DB提供者比较少,但微软正积极推广该技术,并计划用OLE DB取代ODBC。 微软公司已宣布今后不会对VB SQL/DBLib进行升级,而且ODBC API函数一级的编程方式也不为人们所喜爱,所以,RDO今后将被以ActiveX技术为基础的ADO所替代。ADO是基于OLE DB之上的技术,它通过内部的属性和方法提供统一的数据库访问接口。 1ADO组件 Microsoft ActiveX Data Objects (ADO) :使客户端应用程序能通过OLE DB提供者访问和操作数据库服务器中的数据。 ActiveX Data Objects Extensions for DDL and Security(ADOX) :将ADO扩展为包括创建、修改和删除的模式对象,如表格和过程,以及包括用于维护用户和组以及管理对象权限的安全对象。 ActiveX Data Objects (Multidimensional) (ADO MD): 将ADO扩展为包括指定到多维数据的对象,并允许浏览多维模式、查询立方和检索结果。 2ADO优点 ADO具有高度的灵活性,它可以使用相同的编程模式连接到不同的数据提供者,而不管给定提供者的特定特性。 较低的内存占用率。 具有远程数据服务(RDS)功能,通过RDS可以在一次往返过程中将数据从服务器移动到客户端应用程序或Web页,并在客户端对数据进行处理后将更新结果返回服务器。 同传统的数据对象层次(DAO和RDO)不同,ADO可以独立创建。可以只创建一个“Connection”对象,然后由多个独立的“Recordset”对象来使用它。 ODBC本身是以SQL Server、Oracle等关系数据库作为访问对象,而OLE DB则不仅限于此,它还可以对电子邮件、文本文件、复合文件、数据表等各种各样的数据通过统一的接口进行存取。 OLE DB Provider for ODBC是ADO的默认提供者,默认值是MSDASQL,如果省略连接字符串的Provider=参数,ADO将试图建立与该提供者的连接。 ADO的连接方式主要可分为OLE DB Privder方式与OLE DB Provider for ODBC方式。前者很明显是微软公司极力推荐的方式,对于ADO或RDS程序员来说,理想的环境是每个数据源都具有一个OLE DB接口,这比ODBC方式要快且所需资源更少。 ODBC Provider允许ADO连接到任何ODBC数据源。ODBC驱动程序对于当今使用的各种主要DBMS都有效,包括SQL Server、Access、FoxPro,以及诸如Oracle等非微软数据库产品。提供者将不受线程控制,允许使用Unicode,并将支持事务。 连接对象属性 ConnectionString是Connection对象的属性名称,为可读写String类型,提供数据提供者或服务提供者打开到数据源的连接所需要的特定信息,包括Provider、Driver、Server、Database、DSN、UID、PWD或者Provider、Data Source、User、Password、Initial Catalog等。 1Provider 字符串表达式,指定OLE DB数据或服务提供者的名称,可以缺省。 一般有三种提供者:数据提供者、服务提供者和服务组件。数据提供者拥有自己的数据并将数据以表的格式显示给应用程序。服务提供者将服务封装,使ADO应用程序中的功能得以扩大。服务提供者也可以进一步定义为服务组件,服务组件必须连同其他服务提供者或组件一起工作。 Driver 字符串表达式,表示ODBC驱动程序的名称,并不是ODBC驱动程序动态链接库(DLL)的文件名。 有些驱动程序是微软公司的产品,在安装操作系统时就已经安装好了; 而有些数据库产品的驱动程序由开发数据库产品的软件公司随数据库产品一起提供,需要在安装数据库时选择安装后,才可以使用。如:Sybase数据库驱动程序等。 3Server(SRVR) 字符串表达式,数据库服务名称。 4Database(DB) 字符串表达式,指定服务器上的数据库名称。即使DSN定义已经指定了数据库,也可以在DSN之外指定Database参数以便连接到不同的数据库。 5DSN(Data Source) 字符串表达式,在此为空,无须指定连接的ODBC数据源的名称。 6UID(User ID) 字符串表达式,为ODBC数据源指定用户标识(用户账号名),指定用户必须有足够的权限。 7PWD(Password) 字符串表达式,为ODBC数据源指定用户口令,必须有足够的权限。 8Persist Security Info 布尔类型,为True时,表明采用集成安全机制;若为False,则表明不采用集成安全机制。 无DSN(非DSN)连接 除了ADO所定义的参数外,提供者不支持任何特定连接参数,它将把任何非ADO连接参数传递给ODBC驱动程序管理器。下面介绍几种常见数据库的处理方法。 1. Visual Foxpro PROVIDER=MSDASQL.1; 或者为MSDASQL DRIVER=Driver Name; SourceDB=Path; SourceType=DBF 例如: cnna.ConnectionString = “PROVIDER=MSDASQL; ” + “DRIVER=Microsoft Visual Foxpro Driver;” + “SourceDB=D:data;” + “SourceType=DBF” 2SQL Server PROVIDER=MSDASQL; DRIVER=Driver Name; SERVER=server; DATABASE=database; UID=user; PWD=password 例如: cnnb.ConnectionString = “PROVIDER= MSDASQL;” + “DRIVER=SQL Server;” + “SERVER=servera;” + “DATABASE=pubs;” + “UID=sa;” + “PWD=yyuui” 3. Sybase数据库 PROVIDER=MSDASQL; DRIVER=Driver Name; SRVR=server; 必须是SRVR,不能是SERVER DB=database; 可以是DB,也可以是DATABASE DSN=; 可以省略 UID=user; PWD=passwod; PERSIST SECURITY INFO=False 例如: cnnc.ConnectionString= “PROVIDER=MSDASQL;” + “DRIVER=Sybase System 11;” + “SRVR=serveru; ” + “DSN=;” + “DB=dataa;” + “UID=sa;” + “PWD=dqwe;” + “PERSIST SECURITY INFO=False” 4. Oracle数据库 PROVIDER=MSDASQL; DRIVER=Driver Name; SERVER=server; databasename=database; databasefile=path; DSN=; UID=user; PWD=password; 例如: cnnd.ConnectionString = “PROVIDER=MSDASQL; ” + “DRIVER=Microsoft ODBC for Oracle;” + “SERVER=Webserver;” + “DSN=;” + “databasename=dataall;” + “databasefile=d:data;” + “UID=dba;” + “PWD=killer” 应用实例 下面以Sybase 11.9.2为例,编制一个简单的工作人员管理程序,介绍ADO的具体实现方法和步骤。数据库名称为Workerdb,只包括一个表(Worker),其结构如下: 字段名称宽度注释 code nchar(4) 代号 name char(8) 姓名 首先安装ADO,在VB的“工程”/“引用”对话框中选择“ActiveX Data Object 2. 5 Library”(ADODB)。其中“ADO Recordset 2. 5 Library”是一个客户端的版本(ADOR),因为不需要Connection对象来建立与远程数据源的联系,所以ADOR对于客户端的数据访问来说已经足够了。 下面是部分主要代码: 1. 处理代码 在工程菜单中引用Microsoft ActiveX Data Object 2. 5 Library 声明ADO连接对象为工程级全局变量 Public cndbase As New ADODB.Connection 自定义连接数据库函数 Public Function ConnectDbase(StrConnect As String) As Boolean On Error GoTo ErrHandle cndbase.ConnectionString = StrConnect cndbase.Open cndbase.CursorLocation = adUseClient ConnectDbase = True Exit Function ErrHandle: ConnectDbase = False End Function Private Sub Form_Load() 输入 VarServer 服务名称 VarDbase 数据库名称 VarUser 用户名称 VarPassword 用户口令 连接数据库,采取无DSN连接方法 StrConnect = “Provider=MSDASQL;” +“Driver=” & VarDriver &“;” +“SRVR=” & VarServer & “;” +“DB=” & VarDbase & “;” +“DSN=;” +“UID=” & VarUser & “;” +“PWD=” & VarPassword & “;” + “Persist Security Info=False” 不采用集成安全机制 if ConnectDbase(StrConnect) Then Exit Sub else myexit = MsgBox(“数据库连接失败!请检查连接设置信息。”, vbOKOnly, “错误提示:”) Unload me endif ErrHand: myexit = MsgBox(“错误程序:” & Err. Source & Chr(10) & “错误代码:” & Err. Number & Chr(10) & “错误信息:” & Err.Description, VbAbortRetryIgnore, “错误提示:”) If myexit = 3 Then Err.Clear Unload Me Else If myexit = 4 Then Err.Clear Resume Else Err.Clear Resume Next End If End If End Sub Private Sub Form_Unload() cndbase.Close Set cndbase = Nothing End Sub 2. 建表 codbase.CommandText=“call CREATABLE (?) ” codbase.CommandType = adCmdText codbase.Name = “CREATABLE” 设定OutPut的参数 Set param = codbase.CreateParameter(“flag”, adInteger, adParamOutput) codbase. Parameters. Append param Set codbase. ActiveConnection = cndbase codbase. Execute If codbase. Parameters(0) = 0 Then myexit = MsgBox(“建表成功!”, vbOKOnly, “程序提示:”) Else myexit = MsgBox(“建表失败!”, vbOKOnly, “错误提示:”) Endif 3. 修改 rsdbase. Open“worker”,cndbase,adOpenDynamic,adLockPessimistic,adCmdTable rsdbase. MoveFirst cndbase. BeginTrans 在记录集中进行循环更改 Do Until rsdbase.EOF 增加20元职务
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 零售行业新零售技术应用前景预测报告
- 医疗行业人才培养与流动机制研究报告:2025年行业人才发展路径
- 智能家居系统互联互通标准对2025年智能家居市场增长的动力分析报告
- 市南区居家安全知识培训课件
- 装备制造业自主创新能力提升与产业协同创新发展模式报告
- 火灾乘坐电梯安全知识培训
- 左宗棠收复新疆
- 奥迪带货课件
- 灌注桩基础安全知识培训课件
- 2025年电商绿色物流绿色物流服务模式创新研究报告
- (2025年标准)委托他人要账协议书
- 2025-2030中国青少年无人机教育课程体系构建与创新能力培养研究
- 煤矿安全规程新旧版本对照表格版
- 2025山东“才聚齐鲁成就未来”水发集团高校毕业招聘241人笔试参考题库附带答案详解(10套)
- 中学2025年秋季第一学期开学工作方案
- 儿童急救流程
- GB 11122-2025柴油机油
- 私募薪酬管理办法
- 经营废钢管理办法
- 药品经营企业讲课课件
- 广东省深圳市海韵中学2026届中考押题语文预测卷含解析
评论
0/150
提交评论