高分求 根据数据源名称得到数据库路径的API函数(UP有分)

dy_paradise 2003-10-23 01:37:35
在“用户DSN”中添加一个数据源并指定响应的数据库的路径
有没有一个API函数可以根据数据源的名称获得响应数据库的路径呢? 请各位高手指点,谢谢! 在线等待……
...全文
52 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
xieweibbs 2003-10-23
  • 打赏
  • 举报
回复
up!!!

http://xieweibbs.topcities.com
dy_paradise 2003-10-23
  • 打赏
  • 举报
回复
谢谢大家了,结帐了
vcforever 2003-10-23
  • 打赏
  • 举报
回复
楼上mfc168提到的哪个函数其实在内部也是访问注册表,不过用起来比较简单!
如果不想用哪个函数的话也可以用注册表操作的函数,来访问注册表,读取其中的信息
这样也能达到楼主的要求!
这是其中的一个打开注册表的函数
LONG RegOpenKeyEx(
HKEY hKey, // handle to open key
LPCTSTR lpSubKey, // subkey name
DWORD ulOptions, // reserved
REGSAM samDesired, // security access mask
PHKEY phkResult // handle to open key
);
还有其他很多关于注册表的函数,具体就看看MSDN吧!

希望对你有所帮助!
leon_z 2003-10-23
  • 打赏
  • 举报
回复
可以的,我以前用这个方法做过数据库程序的部署(的确很粗糙)

楼上那们兄台的方法似乎更好,楼主还是先试一下他的吧
dy_paradise 2003-10-23
  • 打赏
  • 举报
回复
TO 85125(85125):
这样不可以吧,这样也是受操作系统限制的呀!
mfc168 2003-10-23
  • 打赏
  • 举报
回复
ODBC API里面有
SQLDataSources returns information about a data source. This function is implemented solely by the Driver Manager.

Syntax

SQLRETURN SQLDataSources(
SQLHENV EnvironmentHandle,
SQLUSMALLINT Direction,
SQLCHAR * ServerName,
SQLSMALLINT BufferLength1,
SQLSMALLINT * NameLength1Ptr,
SQLCHAR * Description,
SQLSMALLINT BufferLength2,
SQLSMALLINT * NameLength2Ptr);

leon_z 2003-10-23
  • 打赏
  • 举报
回复
应该是没有直接操作的API,但是可以通过读取注册表信息得到你想要的数据库路径


HKEY_LOCAL_MACHINE\SOFTWARE\ODBC (应该是在这里)

呵呵,我用VC做数据库做得少,加上多用ADO,不太得清是不是这了,如果不对,还请后面的兄弟提个醒

16,550

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • AIGC Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧