在vb中,用microsoft jet数据库引擎和数据访问对象dao(data access object)可以创建功能强大的客户/服务器应用程序。对远程数据库的访问是开发这类应用程序的关键环节,本文将介绍在vb中用dao通过miscrosoft jet数据库引擎访问远程数据库的方法。
用dao访问远程数据库大体上可以通过三步来实现,即数据连接、数据处理和断开连接。下面主要介绍数据连接和数据处理的具体操作。
一、数据连接
dao一般通过链接远程表的方式来进行数据连接。这样,数据虽然驻留在远程数据源上,但在本地的microsoftjet数据库中可以存储与远程数据的永久性连接,同时缓存链接的表结构信息,从而在下一次访问该表时,不用再次从服务器中检索这些结构信息,加快了连接速度。一旦链接了一个表,该链接便会保留在各会话期间,直到连接断开。链接远程表的具体操作是:
用opendatabase方法打开将要包含该链接的本地microsoft jet数据库
用createtabledef方法在该数据库中创建一个新的tabledef对象
将tabledef对象的connect属性设置为一个合法的连接字符串,标识要访问的远程数据库类型、数据文件的路径以及用户名和远程数据源密码等。
将tabledef对象的sourcetablename属性设置为远程数据库中要访问的表的名称。
添加tabledef对象到tabledefs集合中。
实现链接远程表操作的过程如下:
public sub linktable(strdb as string, strrodb as string, strcn as string, strtdf as string, _linktdfname as string)
dim linktdf as new tabledef
set dbs = opendatabase(strdb)
linktdf.name = linktdfname
100
temptable = ucase(linktdf.name)
for i = 0 to dbs.tabledefs.count - 1
if ucase(dbs.tabledefs(i).name) = temptable then
if msgbox(linktdfname + " 已 存 在, 是 否 删 除 ?", _
vbquestion + vbyesno) = vbyes then
dbs.tabledefs.delete linktdf.name
exit for
else: msgbox " 重 新 输 入 新 表 名"
linktdfname = inputbox(" 新 表 名")
goto 100
end if
end if
next i
set linktdf = dbs.createtabledef(linktdfname) ’ 链 接 远 程 表
linktdf.connect = ";database=" + strcn
linktdf.sourcetablename = strtdf
dbs.tabledefs.append linktdf
end sub
Java Asp PHP .Net XML C/C++ CGI VB Jsp J2ee J2se J2me EJB Servlet Tomcat Resin Struts Weblogic Eclipse ANT GUI JMS Web servise IDEA Webphere Hibernate Spring Jboss Applet Swing Socket Javamail Perl Ajax P2P 安全 模式 框架 测试 开源 游戏
Windows XP Windows 2000 Windows 2003 Windows Me Windows 9.x Linux UNIX 注册表 操作系统 服务器 应用服务器