VB中远程数据库的访问(1)-数据连接

2016-02-19 12:27 3 1 收藏

在这个颜值当道,屌丝闪边的时代,拼不过颜值拼内涵,只有知识丰富才能提升一个人的内在气质和修养,所谓人丑就要多学习,今天图老师给大家分享VB中远程数据库的访问(1)-数据连接,希望可以对大家能有小小的帮助。

【 tulaoshi.com - 编程语言 】

在VB中,用microsoftjet数据库引擎和数据访问对象DAO(dataaccessobject)可以创建功能强大的客户/服务器应用程序。对远程数据库的访问是开发这类应用程序的关键环节,本文将介绍在VB中用DAO通过miscrosoftjet数据库引擎访问远程数据库的方法。
  
  用DAO访问远程数据库大体上可以通过三步来实现,即数据连接、数据处理和断开连接。下面主要介绍数据连接和数据处理的具体操作。
  
  一、数据连接
  
  DAO一般通过链接远程表的方式来进行数据连接。这样,数据虽然驻留在远程数据源上,但在本地的microsoftjet数据库中可以存储与远程数据的永久性连接,同时缓存链接的表结构信息,从而在下一次访问该表时,不用再次从服务器中检索这些结构信息,加快了连接速度。一旦链接了一个表,该链接便会保留在各会话期间,直到连接断开。链接远程表的具体操作是:
  
  用opendatabase方法打开将要包含该链接的本地microsoftjet数据库
  
  用createtabledef方法在该数据库中创建一个新的tabledef对象
  
  将tabledef对象的connect属性设置为一个合法的连接字符串,标识要访问的远程数据库类型、数据文件的路径以及用户名和远程数据源密码等。
  
  将tabledef对象的sourcetablename属性设置为远程数据库中要访问的表的名称。
  
  添加tabledef对象到tabledefs集合中。
  
  实现链接远程表操作的过程如下:
  
  publicsublinktable(strdbasstring,strrodbasstring,strcnasstring,strtdfasstring,_linktdfnameasstring)
  
  dimlinktdfasnewtabledef
  
  setdbs=opendatabase(strdb)
  
  linktdf.name=linktdfname
  
  100
  
  temptable=ucase(linktdf.name)
  
  fori=0todbs.tabledefs.count-1
  
  ifucase(dbs.tabledefs(i).name)=temptablethen
  
  ifmsgbox(linktdfname "已存在,是否删除?",_
  
  vbquestion vbyesno)=vbyesthen
  
  dbs.tabledefs.deletelinktdf.name
  
  exitfor
  
  else:msgbox"重新输入新表名"
  
  linktdfname=inputbox("新表名")
  
  goto100
  
  endif
  
  endif
  
  nexti
  
  setlinktdf=dbs.createtabledef(linktdfname)'链接远程表
  
  linktdf.connect=";database=" strcn
  
  linktdf.sourcetablename=strtdf
  
  dbs.tabledefs.appendlinktdf
  
  endsub
  
  上述过程用来实现远程表的连接,它有5个参数,其中strrodb是要访问的远程数据库名(包括路径);strtdf是该数据库中的表名;strdb是要链接的本地数据库(包括路径);linktdfname是本地数据库的一个新表名,用来建立远程表的链接;strcn是指定连接信息的字符串。需要特别注意的是,除了在访问远程microsoftjet数据库时,连接字符串要以分号(;)开头外,指定连接信息的字符串都必须以所访问的远程数据库类型开头。DAO可以访问的远程数据源有以下三类:
  
  .microsoftjet数据源,如:access数据。
  
  .iisam(可安装的索引化顺序访问方法)格式数据源,如:foxpro、paradox、dbase数据。
  
  .odbc数据源,如:sqlserver数据、oracle数据。
  
  例如:设网络服务器名为server,共享目录为c:sales的foxpro3.0数据库,连接字符串应为
  
  strcn="foxpro3.0;database=serverc$salesegion1"
  
  此外,DAO通过microsoftjet数据库引擎访问远程数据时,还可以用opendatabase方法直接打开远程表。在本地数据库中并未存储与远程数据源建立连接所需要的信息。如果使用链接方式访问数据,则不必在每次会话开始时提供连接信息,从而可以提高效率。->

来源:https://www.tulaoshi.com/n/20160219/1600944.html

延伸阅读
1、改表法。 可能是你的帐号不允许从远程登陆,只能在localhost。这个时候只要在localhost的那台电脑,登入mysql后,更改 "mysql" 数据库里的 "user" 表里的 "host" 项,从"localhost"改称"%" mysql -u root -pvmwaremysqluse mysql; mysqlupdate user set host&n...
标签: Java JAVA基础
JDBC数据库访问例子 JAVA语言的跨平台的工作能力(Write Once ,Run Anywhere)、优秀的图像处理能力(我相信现在没有那种语言可以超过JAVA在网络上的图形处理能力)、网络通信功能、通过JDBC数据库访问技术等等,让我们谁都不可否认JAVA语言是SUN公司对于计算机界的一个巨大的贡献。笔者可以描述这样一个场景:有一天你上网完全可以不用IE ...
使用MIDAS访问远程Access数据库 Allen Tao(http://blog.csdn.net/allentao/) 2005-5-3本文源码下载访问远程数据库常用的办法是使用大型数据库自带的客户端工具,如SQL Server和Oracle等都带有这样的工具。带对于Access这样的小型数据库,这种方法就无法使用了,因为Access不提供这样的客户端工具。但我们可以通过MIDAS实现访问远程Access数据...
Visual Basic对Access数据库的集成非常紧密,通常由以下几个部分组成。 引用DAO类型库 1、从“工程”菜单中选择“引用”菜单项; 2、在可引用列表框中选择“Microsoft DAO 3.51 Object Library”项。 3、最后“确定”即可 设置DAO数据类型变量 DAO数据类型变量共分成两种: 1、Database变量 ...
标签: MySQL mysql数据库
一.设置客户端网络实用工具 点击“开始”-“程序”,在“Microsoft SQL Server”菜单中选择“客户端网络实用工具”。 screen.width*0.7) {this.resized=true; this.width=screen.width*0.7; this.alt='点击在新窗口查看全图\nCTRL+鼠标滚轮放大或缩小';}" border=0>  在“别名”选项中点击“添加”。 screen.width*0.7) {this.resize...

经验教程

261

收藏

39
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部