0

我正在尝试使用 ODBC 驱动程序使用 nanodbc 库连接到 MySQL 数据库,这是 ODBC 的 C++ 包装器,但我得到了error LNK2019: unresolved external symbol

我在 nanodbc.lib 所在的附加库目录中添加了安装库目录的路径。我什至在我的源目录中复制了 nanodbc.lib 但仍然没有运气。

我已将 nanodbc.lib 添加到 Properties->Linker->Input->Additional Directories 以防万一#pragma comment(lib, "nanodbc.lib")不工作但它仍然不工作。

最糟糕的部分是相同的代码在现有项目中工作(具有不同的连接字符串)。

工具:Microsoft Visual Studio Community 2017 版本 15.9.11

包管理器:vcpkg

操作系统:Windows 10 专业版 64 位

语言标准:C++17

代码 :

#include <iostream>
#include <nanodbc/nanodbc.h>

#pragma comment(lib, "nanodbc.lib")

int main()
{
    nanodbc::string dns = "PLC_Interface";
    nanodbc::string user_name = "root";
    nanodbc::string password = "rooot";
    nanodbc::connection conn(dns, user_name, password);
    std::cout << conn.connected() << std::endl;
    //std::cout << "Database Name : " <<conn.database_name() << std::endl;
    //std::cout << "DBMS Name : " <<conn.dbms_name() << std::endl;
    //std::cout << "DBMS Version : " <<conn.dbms_version() << std::endl;
    conn.disconnect();
    std::cout << conn.connected() << std::endl;
}

错误 :

error LNK2019: unresolved external symbol "public: __cdecl nanodbc::connection::connection(class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > const &,class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > const &,class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > const &,long)" (??0connection@nanodbc@@QEAA@AEBV?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@00J@Z) referenced in function main
4

1 回答 1

0

解决了这个问题。问题出在 vcpkg 包管理器创建的库上。当我自己手动构建库时,问题得到了解决。无需更改代码(即使使用#pragma)。


想知道他们有什么方法可以比较这些库以找出问题首先出现的原因吗?

于 2019-04-20T08:35:10.070 回答