MySQL, Connector для C ++ | MySQL_Connection :: setReadOnly () исключение на setSchema

Я пишу программу server-emu для не очень популярной игры mmorpg и использую соединитель mysql для c ++ для соединения с моей базой данных. После того, как я переустановил Windows (и всю мою среду разработки), у меня возникло странное исключение для соединителя mysql.

Код, который я использую для соединения с базой данных, выглядит следующим образом:

try
{
this->driver = get_driver_instance();
std::cout << "SQL Driver Name: " << this->driver->getName() << std::endl;
std::cout << "Connecting as " << user << "@" << host << " using password " << password << std::endl;
this->connection = this->driver->connect(host, user, password);
std::cout << "Setting schema to " << schema << std::endl;
this->connection->setSchema(schema);

} catch(sql::SQLException &e)
{
std::cout << "# ERR: SQLException in " << __FILE__;
std::cout << "(" << __FUNCTION__ << ") on line " << __LINE__ << std::endl;
std::cout << "# ERR: " << e.what();
std::cout << " (MySQL error code: " << e.getErrorCode();
std::cout << ", SQLState: " << e.getSQLState() << " )" << std::endl;
return 1;
}

(все переменные, такие как user, password и т. д., являются std :: strings)

Это работало раньше, но теперь оно печатает в консоли это:

SQL Driver Name: MySQL Connector C++ (libmysql)
Connecting as root@tcp://localhost:3306 using password testpassword
Setting schema to testschema
ERR: SQLException in c:\whatever\db.cpp on line 22
ERR: MySQL_Connection::setReadOnly() (MySQL error code: 0, SQLState:  )

Без этой строки:

this->connection->setSchema(schema);

все отлично работает

У меня нет идей, как это исправить и почему это происходит. Пожалуйста помоги.

2

Решение

У меня была похожая проблема, хотя на Debian Wheezy, с версия 1.1.0-4 + b1:

Пример использования:

sql::Connection *con;
con->setSchema(mysql_schema);

Который бросает:

MySQL_Connection :: SetReadOnly ()

Заменив Connector / C ++ 1.1.0-4 + b1 на 1.1.5, он больше не выдает эту ошибку.

0

Другие решения

У меня была такая же проблема; это произошло потому, что я связывал 64-битную версию Connector / C ++ с моей скомпилированной 32-битной программой.

0

да, пожалуйста, используйте v1.1.5. версия 1.16 имеет ошибку.

tar -xf mysql-connector-c++-1.1.5.tar.gz
cd mysql-connector-c++-1.1.5
cmake . -DMYSQL_CONFIG_EXECUTABLE=/usr/local/mysql/bin/mysql_config \
-DMYSQL_LIB=/usr/local/mysql/lib/libmysqlclient.so
make
sudo make install
0
По вопросам рекламы ammmcru@yandex.ru
Adblock
detector