MySQL, Connector C ++ - сделать ошибку 1 - PullRequest
       13

MySQL, Connector C ++ - сделать ошибку 1

0 голосов
/ 21 сентября 2009

Я пишу приложение на C ++ (использующее Eclipse с Linux GCC), которое должно взаимодействовать с моим сервером MySQL. Я скачал MySQL Connector C ++ a, предварительно скомпилировал и скопировал файлы в каталоги (/ usr / lib, / usr / include). Я упоминал в разделе GCC C ++ Linker свойств проекта в Eclipse («mysqlcppconn»). Мой код поступает непосредственно из справочника MySQL (Hello World), за исключением того, что я удалил обработку ошибок и операторы delete в конце (я даже не получаю, так какой смысл)

#include <stdlib.h>
#include <iostream>
#include "mysql_connection.h"
#include "mysql_driver.h"
#include <cppconn/driver.h>
#include <cppconn/exception.h>
#include <cppconn/resultset.h>
#include <cppconn/statement.h>
using namespace std;

int main(void)
{
  sql::Driver *driver;
  sql::Connection *con;
  sql::Statement *stmt;
  sql::ResultSet *res;

  driver = get_driver_instance();
  con = driver->connect("tcp://127.0.0.1:3306", "root", "root");
  con->setSchema("test");

  stmt = con->createStatement();
  res = stmt->executeQuery("SELECT 'Hello World!' AS _message");

  while (res->next()) 
  {
    cout << "\t... MySQL replies: ";
    cout << res->getString("_message") << endl;
    cout << "\t... MySQL says it again: ";
    cout << res->getString(1) << endl;
  }  
return EXIT_SUCCESS;
}

Теперь, когда я компилирую это, он выдает ошибку make 1, которая, как говорит man-страница, означает, что мне нужно перекомпилировать мои пакеты. Я пробовал, это не работает.

Кажется, я везде зашел в тупик. Может кто-нибудь сказать мне, как решить эту проблему? (make может действительно сказать мне, что я должен перекомпилировать.) У кого-нибудь есть какие-либо советы / предложения / идеи, где я ошибся?

Правка - немного изменил код, но общая идея та же.

Обновление - если я использую терминал вместо exlipse для создания, это говорит мне, что проблема, очевидно, в том, что коннектор хочет libstdc ++. So.5, пока у меня есть libstdc ++. So.6.

Ответы [ 2 ]

2 голосов
/ 22 сентября 2009

Решение довольно простое - скомпилируйте свой собственный коннектор. Я сделал это с версией Соединителя 1.0.5. для этого нужно установить пакет через

sudo apt-get install mysql-client

В каталоге исходного пакета, который вы скачали (и распаковали), введите

cmake .

по-видимому, в трех файлах драйвера имеются ссылки на snprintf и printf без заголовка stdio.h. Я добавил

#include <stdio.h>

для каждого файла, а затем в терминале наберите

make

Затем я скопировал файлы в каталог lib

sudo cp path/to/driver/libmysqlcppconn* /usr/lib/

и каждый наградил заклинанием.

1 голос
/ 21 сентября 2009

Загрузите и установите пакеты разработки C ++ MySQL для вашего дистрибутива. Для Ubuntu запустите # sudo apt-get install libmysql ++ - dev.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...