将C ++程序连接到数据库时出现错误LNK2019

时间:2014-07-29 13:43:45

标签: c++ mysql

我正在使用visual C ++ 2010,我正在启动一个需要连接数据库的项目

我从包括

开始
  1. C:\ Program Files \ boost_1_55_0
  2. C:\ Program Files \ MySQL \ Connector C ++ 1.1.3 \ include
  3. 到C ++ - >一般,也是

    1. C:\ Program Files \ MySQL \ Connector C ++ 1.1.3 \ lib \ opt
    2. to Linker-> General和set Linker->输入mysqlcppconn.lib

      最后我将mysqlcppconn.dll和libmysql.dll移动到调试文件夹下的项目中。

      它仍然有LINK2019错误。有什么问题?

      error LNK2019: unresolved external symbol "__declspec(dllimport) public: class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > const & __thiscall sql::SQLException::getSQLState(void)const " (__imp_?getSQLState@SQLException@sql@@QBEABV?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@XZ) referenced in function __catch$_main$0
      error LNK2019: unresolved external symbol "__declspec(dllimport) public: int __thiscall sql::SQLException::getErrorCode(void)const " (__imp_?getErrorCode@SQLException@sql@@QBEHXZ) referenced in function __catch$_main$0
      error LNK2019: unresolved external symbol "__declspec(dllimport) public: __thiscall sql::SQLString::~SQLString(void)" (__imp_??1SQLString@sql@@QAE@XZ) referenced in function _main
      error LNK2019: unresolved external symbol "__declspec(dllimport) public: __thiscall sql::SQLString::SQLString(char const * const)" (__imp_??0SQLString@sql@@QAE@QBD@Z) referenced in function _main
      error LNK2019: unresolved external symbol __imp__get_driver_instance referenced in function _main
      

      以下是我的代码

      #include "stdafx.h"
      #include <mysql_connection.h>  
      #include <cppconn/driver.h>  
      #include <cppconn/exception.h>  
      #include <cppconn/resultset.h>  
      #include <cppconn/statement.h> 
      
      using namespace std;  
      
      int main(int argc, _TCHAR* argv[])
      {
          try {  
              sql::Driver *driver;  
              sql::Connection *con;  
              sql::Statement *stmt;  
              sql::ResultSet *res;  
              sql::PreparedStatement *pstmt;
      
              driver = get_driver_instance();  
              con = driver->connect("localhost", "user_name", "password");  
      
              con->setSchema("test"); 
      
              con->setClientOption("characterSetResults", "utf8");
              stmt = con->createStatement();  
              res = stmt->executeQuery("SELECT * from user");  
      
              while (res->next())   
              {  
      
                  int id = res->getInt("ID");
                  cout<<id<<endl;
      
      
              } 
              delete res;  
              delete stmt;
              delete con;  
          } catch (sql::SQLException &e) {  
      
              cout << "# ERR: SQLException in " << __FILE__;  
              cout << "(" << __FUNCTION__ << ") on line "  
                  << __LINE__ << endl;  
              cout << "# ERR: " << e.what();  
              cout << " (MySQL error code: " << e.getErrorCode();  
              cout << ", SQLState: " << e.getSQLState() << " )" << endl;  
          }  
          return 0;
      }
      

0 个答案:

没有答案