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++ 的第二天,所以请原谅我的严重格式化编码和其他 nooby 错误。这总是在我遇到未处理的异常之前出现。

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 回答