| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 598 人关注过本帖
标题:数据库位置问题
只看楼主 加入收藏
court1
Rank: 1
等 级:新手上路
帖 子:20
专家分:0
注 册:2010-7-27
结帖率:50%
收藏
已结贴  问题点数:20 回复次数:4 
数据库位置问题
各位大哥大姐好 小弟初学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打包成一起 ,形成一个可运行文件

要达到这两种效果分别怎么实现?
搜索更多相关主题的帖子: 数据库 位置 
2010-08-02 11:39
东海一鱼
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:48
帖 子:757
专家分:4760
注 册:2009-8-10
收藏
得分:0 
1、你可以在程序运行时,用GetCurrentDirectory获得你的可执行文件当前目录,
用这个目录字串 + mdb文件名来做ADOConnection的connectionstring。

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

3、以上两者可以结合使用。

举世而誉之而不加劝,举世而非之而不加沮,定乎内外之分,辩乎荣辱之境,斯已矣。彼其于世未数数然也。
2010-08-02 11:56
court1
Rank: 1
等 级:新手上路
帖 子:20
专家分:0
注 册:2010-7-27
收藏
得分:0 
回复 2楼 东海一鱼
我是初学者 你说我还不能完全理解 具体操作不会 最好能附上代码演示说明 不过还是要谢谢你回复!
2010-08-02 15:12
东海一鱼
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:48
帖 子:757
专家分:4760
注 册:2009-8-10
收藏
得分:20 
调用这个API
DWORD GetCurrentDirectory(
  DWORD nBufferLength,  // size of directory buffer
  LPTSTR lpBuffer       // directory buffer
);

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


举世而誉之而不加劝,举世而非之而不加沮,定乎内外之分,辩乎荣辱之境,斯已矣。彼其于世未数数然也。
2010-08-02 18:52
court1
Rank: 1
等 级:新手上路
帖 子:20
专家分:0
注 册:2010-7-27
收藏
得分:0 
非常感谢!
2010-08-04 09:03
快速回复:数据库位置问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.025048 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved