2016-11-19 6 views
-1

Я использую SQLPP11 для запросов и результатов sql и SQLPP11-Connector-mysql для установления соединения с базой данных.undefined ссылка на `sqlpp :: mysql :: connection :: ~ connection() '

и компиляции моей программы с помощью

g++ -std=c++1y main.cpp -I ../date -lsqlpp-mysql -lmysqlclient -lboost_system -lpthread 

А вот пример кода я использую.

bool db_connection() 
{ 
    auto config = std::make_shared<mysql::connection_config>(); 
    config->user = "root"; 
    config->password = ""; 
    config->database = "test"; 
    config->debug = true; 
    sqlpp::mysql::connection db(config); 
    try 
    { 
     sqlpp::mysql::connection db(config); 
     std::cout << "Database connection establish...!!\n"; 

     std::cout << "Now executing a very simple select query in table using sqlpp11 \n"; 

     const auto g = changestreet::Goals{}; 
     for(const auto& row : db(select(all_of(g)).from(g).unconditionally())) 
     { 
      std::cerr << row.goalId << "\n"; 
      std::cerr << row.goalName << "\n"; 
      std::cerr << row.goalAmount << "\n"; 
     } 

    } 
    catch (const sqlpp::exception& e) 
    { 
     std::cerr << "No such database exits, you'll need to create it. \n"; 
     std::cerr << e.what() << std::endl; 
     return false; 
    } 

    return true; 
} 

И ошибки

/tmp/ccxRheKs.o: In function `db_connection_cs()': 
main.cpp:(.text+0x39d): undefined reference to `sqlpp::mysql::connection::connection(std::shared_ptr<sqlpp::mysql::connection_config> const&)' 
main.cpp:(.text+0x3c8): undefined reference to `sqlpp::mysql::connection::~connection()' 
main.cpp:(.text+0x400): undefined reference to `sqlpp::mysql::connection::~connection()' 
/tmp/ccxRheKs.o: In function `db_connection_nav()': 
main.cpp:(.text+0x4bf): undefined reference to `sqlpp::mysql::connection::connection(std::shared_ptr<sqlpp::mysql::connection_config> const&)' 
main.cpp:(.text+0x4ea): undefined reference to `sqlpp::mysql::connection::~connection()' 
main.cpp:(.text+0x522): undefined reference to `sqlpp::mysql::connection::~connection()' 
/tmp/ccxRheKs.o: In function `sqlpp::mysql::serializer_t::escape(std::string)': 
main.cpp:(.text._ZN5sqlpp5mysql12serializer_t6escapeESs[_ZN5sqlpp5mysql12serializer_t6escapeESs]+0x2a): undefined reference to `sqlpp::mysql::connection::escape(std::string const&) const' 
/tmp/ccxRheKs.o: In function `sqlpp::result_t<sqlpp::mysql::char_result_t, sqlpp::result_row_t<sqlpp::mysql::connection, sqlpp::field_spec_t<changestreet::Goals_::GoalId::_alias_t, sqlpp::integral, false, false>, sqlpp::field_spec_t<changestreet::Goals_::GoalName::_alias_t, sqlpp::text, true, false>, sqlpp::field_spec_t<changestreet::Goals_::GoalAmount::_alias_t, sqlpp::floating_point, true, false>, sqlpp::field_spec_t<changestreet::Goals_::GoalStartTime::_alias_t, sqlpp::day_point, true, false>, sqlpp::field_spec_t<changestreet::Goals_::GoalEndTime::_alias_t, sqlpp::day_point, true, false>, sqlpp::field_spec_t<changestreet::Goals_::GoalMonthlyContribution::_alias_t, sqlpp::floating_point, true, false>, sqlpp::field_spec_t<changestreet::Goals_::GoalStatus::_alias_t, sqlpp::text, true, false>, sqlpp::field_spec_t<changestreet::Goals_::UsersUserId::_alias_t, sqlpp::integral, true, false> > >::~result_t()': 
main.cpp:(.text._ZN5sqlpp8result_tINS_5mysql13char_result_tENS_12result_ro 

Вот build logs обеих библиотек на моем 64 битной DEBiAN машине.

ответ

1

Наконец, я выяснил решение.

Это была проблема с версией g ++. У последних версий g++-5 и g++-6 есть такие проблемы, но когда я вернусь к старой версии g++ версии 4.9.2, все работает гладко.

+1

Это означает, что libsqlpp-mysql строился с другим компилятором, чем тот, с которым вы пытались использовать библиотеку. Я бы поставил вопрос, что проблема исчезнет, ​​если вы сообщите CMake о создании библиотеки с помощью «g ++ - 5» или «g ++ - 6» вместо системного по умолчанию. – ildjarn

0

"undefined reference to" обычно означает, что компоновщик не может найти нужную библиотеку. Убедитесь, что в вашей среде PATH есть те libs sqlpp-mysql mysqlclient в области.

+1

Не мог ли компоновщик дать сообщение об ошибке, если он не смог найти библиотеку, которую пользователь указал? – ildjarn

+0

Ну. Пользователь может установить несколько версий библиотеки, и что-то (путь, .so имя и т. Д.) Путает компоновщик. – Ripi2