1

私はこれを数日間見ていて、たくさんのテストをしましたが、それでも動作させることができません。Npgsql 2.0.11.91(2.0.11も試しました)とPostgreSQL9.04を使用しています。

ここにあるNpgsqlのユーザーマニュアルの例を使用します。「.NETデータセットの操作」を検索して、例を確認してください。そのままでも問題なく動作しますが、ニーズに合わせて変更しようとしています。

私のコードは以下の通りです。何をしようとしても、なんらかのエラーが発生します。以下のコードを使用すると、ユーザーマニュアルに記載されているものとほぼ同じであり、NpgsqlExceptionがユーザーコードによって処理されなかったことがわかります。

ERROR: 42601: syntax error at or near ":".
private void tryThis()
{
    // This method expects the following table in the backend:
    //
    //  create table customers(code varchar, reference varchar, description varchar, street varchar, suburb varchar, postcode varchar);
    //
    //

    NpgsqlConnection conn = new NpgsqlConnection("Server=127.0.0.1;Port=5432;User Id=postgres;Password=password;Database=testdatabase;");
    conn.Open();

    DataSet ds = new DataSet();

    NpgsqlDataAdapter da = new NpgsqlDataAdapter("select * from customers", conn);

    da.InsertCommand = new NpgsqlCommand("insert into customers(code, reference, description, street, suburb, postcode) " +
                                " values (:a, :b, :c, :d, :e, :f)", conn);

    da.InsertCommand.Parameters.Add(new NpgsqlParameter("a", NpgsqlDbType.Varchar));
    da.InsertCommand.Parameters.Add(new NpgsqlParameter("b", NpgsqlDbType.Varchar));
    da.InsertCommand.Parameters.Add(new NpgsqlParameter("c", NpgsqlDbType.Varchar));
    da.InsertCommand.Parameters.Add(new NpgsqlParameter("e", NpgsqlDbType.Varchar));
    da.InsertCommand.Parameters.Add(new NpgsqlParameter("e", NpgsqlDbType.Varchar));
    da.InsertCommand.Parameters.Add(new NpgsqlParameter("f", NpgsqlDbType.Varchar));

    da.InsertCommand.Parameters[0].Direction = ParameterDirection.Input;
    da.InsertCommand.Parameters[1].Direction = ParameterDirection.Input;
    da.InsertCommand.Parameters[2].Direction = ParameterDirection.Input;
    da.InsertCommand.Parameters[3].Direction = ParameterDirection.Input;
    da.InsertCommand.Parameters[4].Direction = ParameterDirection.Input;
    da.InsertCommand.Parameters[5].Direction = ParameterDirection.Input;

    da.InsertCommand.Parameters[0].SourceColumn = "code";
    da.InsertCommand.Parameters[1].SourceColumn = "reference";
    da.InsertCommand.Parameters[2].SourceColumn = "description";
    da.InsertCommand.Parameters[3].SourceColumn = "street";
    da.InsertCommand.Parameters[4].SourceColumn = "suburb";
    da.InsertCommand.Parameters[5].SourceColumn = "postcode";

    da.Fill(ds);

    DataTable dt = ds.Tables[0];

    DataRow dr = dt.NewRow();
    dr["code"] = "CUST1";
    dr["reference"] = "C";
    dr["description"] = "Customer 1";
    dr["street"] = "1 Big Street";
    dr["suburb"] = "BRISBANE QLD";
    dr["postcode"] = "4000";
    dt.Rows.Add(dr);

    DataSet ds2 = ds.GetChanges();

    da.Update(ds2);

    ds.Merge(ds2);
    ds.AcceptChanges();
}

何か案は?

ピート。

4

2 に答える 2

4

パラメータをまったく追加せずに、パラメータeを2回追加dします...

編集(上記のコードから):

da.InsertCommand.Parameters.Add(new NpgsqlParameter("e", NpgsqlDbType.Varchar));
da.InsertCommand.Parameters.Add(new NpgsqlParameter("e", NpgsqlDbType.Varchar));
于 2011-07-19T23:54:24.717 に答える
1

また、npgsqlのドキュメントに従って問題が発生し、コロンを使用してパラメーターを宣言するときにエラーが発生していました。最新バージョンでは、.NETスタイルのAddWithValueを使用できることがわかりました。

cmd.Parameters.AddWithValue("@paramName", paramValue);
于 2011-09-22T16:13:37.850 に答える