c++ - 在未安装驱动程序的情况下连接ODBC

标签 c++ database odbc database-connection

是否可以在未安装系统级驱动程序的情况下进行ODBC连接?我可以仅指向包含驱动程序的DLL吗?

我在32位元的C++中使用它,目前正在Windows上进行测试,并连接到Firebird数据库。我尝试了以下连接字符串,但不起作用:

constexpr auto DatabaseConnection =
//"DRIVER=Firebird/InterBase(r) driver;" //this works when driver installed
"UID=SYSDBA;"
"PWD=masterkey;"
"DBNAME=C:\\some\\path\\to\\database\\DB.FDB;"
"Client=C:\\Windows\\System32\\OdbcFb.dll;";

错误消息:[Microsoft][ODBC Driver Manager] Data source name not found and no default driver specified

最佳答案

是的,可以通过完全指定连接字符串来与未注册的ODBC驱动程序建立无DSN的连接。

正确安装驱动程序时使用的这一行-

"DRIVER=Firebird/InterBase(r) driver;"

-实际上应该是这样,以按名称引用驱动程序-
"DRIVER={Firebird/InterBase(r) driver};"

-应该改为-
"DRIVER=C:\\Windows\\System32\\OdbcFb.dll;"

看来,如果未正确设置%PATH%(以包含包含odbcfb.dll的目录)和/或如果未在MDAC驱动程序管理器中注册FB驱动程序,则必须在其中包含指向client的FB特定的odbcfb.dll关键字。在这种情况下,您不需要任何对odbcfb.lib的引用。

您可能会受益于阅读驱动程序自己的creating DSNsDNSless connections文档...

关于c++ - 在未安装驱动程序的情况下连接ODBC,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54826254/

相关文章:

c - 共享对象中的函数名称冲突

c++ - 使用 C/C++ 获取正在运行的进程的当前 NT header 数据

c++ - EFAULT 尝试发送字符时

c++ - CRT 内存泄漏检测未检测到内存泄漏

python - 如何将 Django 连接到 MongoDB 数据库?

mysql - 更好的数据库设计?

c++ - 从 Qt 类派生的用户定义类中的内存所有权

database - ORACLE 中的 SYSDATE

stored-procedures - 如何使用 odbc :param_query in Erlang 调用获取数组的存储过程

c++ - 使用可为 Null 的参数调用 PL/PGSQL 函数