2
#include "StdAfx.h"
#include <stdlib.h>
#include <iostream>

#include "mysql_connection.h"

#include <cppconn/driver.h>
#include <cppconn/exception.h>
#include <cppconn/resultset.h>
#include <cppconn/statement.h>
#include <cppconn/prepared_statement.h>

using namespace std;

int main(void){
    cout << endl;

    try{
        sql::Driver *driver;
        sql::Connection *con;
        sql::Statement *stmt;
        sql::ResultSet *res;
        sql::PreparedStatement *pstmt;

        driver = get_driver_instance();
        con = driver->connect("REMOVED", "REMOVED", "REMOVED");
        con->setSchema("REMOVED");

        stmt = con->createStatement();
        res = stmt->executeQuery("SELECT username FROM player WHERE id=1");

        cout << "Username: " << res->getString("username") << endl;

        delete res;
        delete con;

        cout << "Done.";
        system("pause");

    }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() << endl;
        cout << ", SQLState: " << e.getSQLState() << " )" << endl;
        system("pause");
    }

    return 0;
}

に変わります... http://i.imgur.com/cIVnl.png

何が起こっていますか?:( C++ を使ったのはまだ 2 日目なので、私のひどくフォーマットされたコーディングやその他の面倒なミスを許してください。これは、未処理の例外が発生する直前に常に表示されます。

4

1 に答える 1

0

使用している API は std::string オブジェクトを返すと思います。

この場合#include <sstream>、コードの先頭に a を追加して、std::string クラスの '<<' 演算子を適切に定義することをお勧めします。

演算子「<<」が見つからないことを何らかの形で示唆するコンパイルエラーが発生すると予想していたため、この解決策については確信が持てません。

これをコードに貼り付けて、すぐに main() から呼び出してみて、ストリーミング オペレーターが機能しているかどうかを確認してください。プログラムが終了することに注意してください。

void SimpleStrings()
{
    std::string str("String in a std::string");
    const char *psz = "const-char-str";
    std::cout << "std::string: " << str << std::endl << "const char *: " << psz << std::endl;
    exit(1);
}
于 2012-03-06T20:39:17.430 に答える