0

mySQLデータベースに接続するために必要なVisualC++2010でc++コンソールアプリケーションを開発しています。mysql用のwampサーバーとmySQLC++コネクタを使用して接続しています。コードはデータベースの読み取りには問題なく機能しますが、データを挿入しようとすると、予期しないエラーが発生します。誰もがそのような経験をしましたか?

これが私の完全なコードです:(コードの出力は: "SQLエラー:エラーメッセージ:不明な例外")

    // Standad C++ includes
#include <iostream>
#include <cstdlib>
#include <string>
using namespace std;

// Include the Connector/C++ headers
#include "cppconn/driver.h"
#include "cppconn/exception.h"
#include "cppconn/resultset.h"
#include "cppconn/statement.h"
#include "cppconn/sqlstring.h"

// Link to the Connector/C++ library
#pragma comment(lib, "mysqlcppconn.lib")

// Specify our connection target and credentials
const string server   = "tcp://127.0.0.1:3306";
const string username = "cashif";
const string password = "111222"; // No password - NEVER DO THIS ON A PRODUCTION SERVER!

int main()
{
    sql::Driver     *driver; // Create a pointer to a MySQL driver object
    sql::Connection *dbConn; // Create a pointer to a database connection object
    sql::Statement  *stmt;   // Create a pointer to a Statement object to hold our SQL commands
    sql::ResultSet  *res;    // Create a pointer to a ResultSet object to hold the results of any queries we run

    // Try to get a driver to use to connect to our DBMS
    try
    {
        driver = get_driver_instance();
    }
    catch (sql::SQLException e)
    {
        cout << "Could not get a database driver. Error message: " << e.what() << endl;
        system("pause");
        exit(1);
    }

    // Try to connect to the DBMS server
    try
    {
        dbConn = driver->connect(server, username, password);
    }
    catch (sql::SQLException e)
    {
        cout << "Could not connect to database. Error message: " << e.what() << endl;
        system("pause");
        exit(1);
    }

    stmt = dbConn->createStatement(); // Specify which connection our SQL statement should be executed on

    // Try to query the database
    try
    {
        stmt->execute("use dengue_test");              // Select which database to use. Notice that we use "execute" to perform a command.

        stmt->execute("insert into patients values(3,\"Amina\",\"Iqbal Town\""); // Perform a query and get the results. Notice that we use "executeQuery" to get results back
    }
    catch (sql::SQLException e)
    {
        cout << "SQL error. Error message: " << e.what() << endl;
        system("pause");
        exit(1);
    }

    // While there are still results (i.e. rows/records) in our result set...
/*
    while (res->next())
    {
        // ...get each field we want and output it to the screen
        // Note: The first field/column in our result-set is field 1 (one) and -NOT- field 0 (zero)
        // Also, if we know the name of the field then we can also get it directly by name by using:
        // res->getString("TheNameOfTheField");
        cout << res->getString(1) << " - " << res->getString(2) << " - " << res->getString(3) << endl;                
    }
    */
    // Clean up after ourselves
    //delete res;
    delete stmt;
    delete dbConn;

    system("pause");
    return 0;
}
4

1 に答える 1

1

SQLには2つのエラーがあります。1つはMySQLで回避できるエラーで、もう1つは回避できないエラーです。あなたはまた悪い習慣を身につけています。

両方のバグがここにあります:

stmt->execute("insert into patients values(3,\"Amina\",\"Iqbal Town\"");

SQLの文字列リテラルは、二重引用符ではなく一重引用符を使用します。ただし、MySQLを使用すると、これを回避できます。ただし、閉じ括弧が欠落しているため、MySQLはその1ビットを好みません。あなたはこれを言うべきです:

stmt->execute("insert into patients values(3, 'Amina', 'Iqbal Town')");

SQL INSERTで列を指定しないのは悪い習慣なので、次のように言う必要があります。

insert into patients (col1, col2, col3) values (...)

もちろん、 wherecol1とfriendsは実際の列名です。テーブルの列には明確に定義された順序がないため、興味深いバグやメンテナンスの悪夢を避けるために具体的にする必要があります。

于 2012-05-05T04:06:13.440 に答える