簡體   English   中英

適用於C ++的MySQL連接器| setSchema上的MySQL_Connection :: setReadOnly()異常

[英]MySQL Connector for C++ | MySQL_Connection::setReadOnly() exception on setSchema

我正在為一個不太受歡迎的mmorpg游戲編寫服務器-軟件,並且我正在使用mysql Connector for 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;
}

(所有變量,例如用戶,密碼等都是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);

一切正常。

我不知道如何解決這個問題以及為什么會這樣。 請幫忙。

我在Debian Wheezy上有一個類似的問題, 版本為1.1.0-4 + b1

用法示例:

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

哪個拋出:

MySQL_Connection :: setReadOnly()

通過用1.1.5替換Connector / C ++ 1.1.0-4 + b1,它不再引發此錯誤。

我遇到了同樣的問題; 原來是因為我將64位版本的Connector / C ++鏈接到我的32位編譯程序。

是的,請使用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

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM