注册 登录
编程论坛 Delphi论坛

数据库位置问题

court1 发布于 2010-08-02 11:39, 598 次点击
各位大哥大姐好 小弟初学delphi 最近碰到一棘手问题 :我用delphi+access数据库编出来的程序
受access数据库位置影响 ,只要一移动access数据库就会出现“连接不上数据库错误”这样一来
access无法移动,怎么办 如何解决 使得编译的exe文件不受它限制。

以下是我ADOConnection的connectionstring里的内容:
(Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\Documents and Settings\E43\桌面\manage.mdb;Persist Security Info=False)

我要实现以下效果 (有第一种最好):
1 我编译的工程文件和access放在一个文件夹里 ,把整个文件夹一起移动时,可保证正常运行。
2 把编译出来的国内工程文件和access打包成一起 ,形成一个可运行文件

要达到这两种效果分别怎么实现?
4 回复
#2
东海一鱼2010-08-02 11:56
1、你可以在程序运行时,用GetCurrentDirectory获得你的可执行文件当前目录,
用这个目录字串 + mdb文件名来做ADOConnection的connectionstring。

2、把你的MDB文件做成资源,加入你的可知性文件中。运行时释放出来。

3、以上两者可以结合使用。
#3
court12010-08-02 15:12
回复 2楼 东海一鱼
我是初学者 你说我还不能完全理解 具体操作不会 最好能附上代码演示说明 不过还是要谢谢你回复!
#4
东海一鱼2010-08-02 18:52
调用这个API
DWORD GetCurrentDirectory(
  DWORD nBufferLength,  // size of directory buffer
  LPTSTR lpBuffer       // directory buffer
);

成功了就会返回你的程序的安装路径,你用这个路径字串 + 你的mdb文件名不就是你的ADOConnection的connectionstring连结路径吗?

#5
court12010-08-04 09:03
非常感谢!
1