当前位置:中国易下载软件教材中心文章中心编程语言VB语言 → VB中远程数据库的访问

VB中远程数据库的访问

减小字体 增大字体 作者:佚名  来源:不详  发布时间:2007-8-21 1:02:17
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
喜欢这些内容嘛,请告诉你身边的朋友,易下载中心-QQ资源-itnetcn.com一起享受这份乐趣,本站内容来源互联网
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

 在VB中,用数据库引擎和数据访问对象DAO可以创建功能强大的客户/服务器应用程序。对远程数据库的访问是开发这类应用程序的关键,本文将介绍在VB中用DAO通过数据库引擎访问远程数据库的方法。 n9k海岸线网络安全资讯站
n9k海岸线网络安全资讯站
  用DAO访问远程数据库可以通过三步来实现,即数据连接、数据处理和断开连接。下面主要介绍数据连接和数据处理的具体操作。 n9k海岸线网络安全资讯站
n9k海岸线网络安全资讯站
  数据连接n9k海岸线网络安全资讯站
n9k海岸线网络安全资讯站
  DAO通过链接远程表的方式来进行数据连接。这样,数据虽然驻留在远程数据源上,但在本地的数据库中可以存储与远程数据的永久性连接,同时缓存链接的表结构信息,从而在下一次访问该表时, 不用再次从服务器中检索这些结构信息,加快了连接速度。一旦链接了一个表,该链接便会保留在各会话期间,直到连接断开。链接远程表的具体操作是: n9k海岸线网络安全资讯站
n9k海岸线网络安全资讯站
  用 OpenDatabase 方法打开将要包含该链接的本地数据库,用 CreateTableDef 方法在该数据库中创建一个新的TableDef对象,将 TableDef 对象的 Connect 属性设置为一个合法的连接字符串,标识要访问的远程数据库类型、数据文件的路径以及用户名和远程数据源密码等。将 TableDef 对象的 SourceTableName 属性设置为远程数据库中要访问的表的名称。 添加 TableDef 对象到 TableDefs 集合中。 n9k海岸线网络安全资讯站
n9k海岸线网络安全资讯站
  实现链接远程表操作的代码如下: n9k海岸线网络安全资讯站
n9k海岸线网络安全资讯站
  Public Sub LinkTable(strDB As String, strRoDB As String, _n9k海岸线网络安全资讯站
  strCn As String, strTdf As String, linkTdfName As String)n9k海岸线网络安全资讯站
  Dim linkTdf As New TableDefn9k海岸线网络安全资讯站
  Set dbs = OpenDatabase(strDB)n9k海岸线网络安全资讯站
  linkTdf.Name = linkTdfName 100n9k海岸线网络安全资讯站
  tempTable = UCase(linkTdf.Name)n9k海岸线网络安全资讯站
  For i = 0 To dbs.TableDefs.Count - 1n9k海岸线网络安全资讯站
    If UCase(dbs.TableDefs(i).Name) = tempTable Thenn9k海岸线网络安全资讯站
      If MsgBox(linkTdfName + " 已存在,是否删除 ?", _n9k海岸线网络安全资讯站
      vbQuestion + vbYesNo) = vbYes Thenn9k海岸线网络安全资讯站
        dbs.TableDefs.Delete linkTdf.Namen9k海岸线网络安全资讯站
        Exit Forn9k海岸线网络安全资讯站
      Else: MsgBox "重新输入新表名"n9k海岸线网络安全资讯站
      linkTdfName = InputBox(" 新表名")n9k海岸线网络安全资讯站
      GoTo 100n9k海岸线网络安全资讯站
      End Ifn9k海岸线网络安全资讯站
    End Ifn9k海岸线网络安全资讯站
  Next in9k海岸线网络安全资讯站
Set linkTdf = dbs.CreateTableDef(linkTdfName)  注释:链接远程表n9k海岸线网络安全资讯站
  linkTdf.Connect = ";database=" + strCnn9k海岸线网络安全资讯站
  linkTdf.SourceTableName = strTdfn9k海岸线网络安全资讯站
  dbs.TableDefs.Append linkTdfn9k海岸线网络安全资讯站
End Subn9k海岸线网络安全资讯站
  上述过程用来实现远程表的连接,它有5个参数,其中strRoDB是要访问的远程数据库名(包括路径);strTdf 是该数据库中的表名;strDB 是要链接的本地数据库(包括路径);linkTdfName 是本地数据库的一个新表名,用来建立远程表的链接;strCn 是指定连接信息的字符串。需要特别注意的是,除了在访问远程 Microsoft Jet 数据库时,连接字符串要以分号(;)开头外,指定连接信息的字符串都必须以所访问的远程数据库类型开头。DAO可以访问的远程数据源有以下三类: n9k海岸线网络安全资讯站
n9k海岸线网络安全资讯站
  Microsoft Jet 数据源,如:Access 数据。n9k海岸线网络安全资讯站
n9k海岸线网络安全资讯站
  IISAM(可安装的索引化顺序访问方法)格式数据源,如:FoxPro、Paradox、dBASE 数据。 n9k海岸线网络安全资讯站
ODBC 数据源,如:SQL Server 数据、Oracle 数据。 n9k海岸线网络安全资讯站
n9k海岸线网络安全资讯站
  例如:设网络服务器名为server,共享目录为 C:Sales 的 FoxPro数据库,连接字符串应为strCn="FoxPro3.0;database=serverc$SalesRegion1" n9k海岸线网络安全资讯站
n9k海岸线网络安全资讯站