我正在尝试使用 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