3

次のような C# コードを使用して、DB2 データベースに複数の行を挿入しようとしています。

string query = 
"INSERT INTO TESTDB2.RG_Table (V,E,L,N,Q,B,S,P) values" +
"('abc', 'def', '2009-03-27 12:01:19', 'ghi', 'jkl', NULL, NULL, NULL)," +
"('abc', 'def', '2009-03-27 12:01:19', 'ghi', 'jkl', NULL, NULL, NULL)";

DB2Command cmd = new DB2Command(query, this.connection, this.transaction);

cmd.ExecuteNonQuery();

最初の一連の値の後にクエリ文字列の作成を停止すると、エラーなしで実行されます。このメソッドを使用して複数の値を読み込もうとすると、次のエラーが発生します。

Upload error : ERROR [42601] [IBM][DB2] SQL0104N  
An unexpected token "," was found following "".  
Expected tokens may include:  "<END-OF-STATEMENT>".  SQLSTATE=42601

SQL 構文は、私が他の場所で読んだものと一致し、IBM のドキュメントには次の例が示されています。

cmd = conn.CreateCommand();
cmd.Transaction = trans;

cmd.CommandText =
"INSERT INTO company_a VALUES(5275, 'Sanders', 20, 'Mgr', 15, 18357.50), " +
"(5265, 'Pernal', 20, 'Sales', NULL, 18171.25), " +
"(5791, 'O''Brien', 38, 'Sales', 9, 18006.00)";

cmd.ExecuteNonQuery();

誰がこれを説明できるのか説明できますか?

4

4 に答える 4

2

これは非常に古い質問だと思いますが、これまでのところ、問題の真の根源に到達した回答はありません. 彼は複数の VALUES 句を使用できないため、サポートしていない z/OS を使用していると推測します。詳細については、こちらの他の回答を参照してください。

ただし、ドライバーの「連鎖」機能である .NET を使用しているように見えるため、別の方法があります。これにより、複数の挿入/更新/削除をバッチ処理でき、チェーンを「終了」すると、ドライバーはすべてのステートメントを一度に送信します。コード例を次に示します。

<!-- language: lang-cs --> //Code parser seems to be going crazy here...
public void InsertToDatabase(IEnumerable<Row> rows)
{
    using (var conn = new DB2Connection())
    using (var trans = conn.BeginTransaction())
    using (var cmd = conn.CreateCommand())
    {
        cmd.Transaction = trans;
        cmd.CommandText =
            "INSERT INTO company_a VALUES " +
            "(@field1,@field2,@field3,@field4,@field5,@field6)";

        conn.BeginChain();
        foreach (var row in rows)
        {
            cmd.Parameters.Clear();
            cmd.Parameters.Add("@field1", row.Field1);
            cmd.Parameters.Add("@field2", row.Field2);
            cmd.Parameters.Add("@field3", row.Field3);
            cmd.Parameters.Add("@field4", row.Field4);
            cmd.Parameters.Add("@field5", row.Field5);
            cmd.Parameters.Add("@field6", row.Field6);
            cmd.ExecuteNonQuery();
        }
        conn.EndChain();
        trans.Commit();
    }
}

DB2 が何らかの例外をスローした場合、それは を実行したときにのみ取得されEndChain、それらはすべて一度に発生します。

于 2016-01-13T18:08:12.413 に答える
0

あなたの構文はおおむね正しく見えます。

  • それはcliから動作しますか?
  • JDBC バッチ更新をご覧になりましたか。ほぼ同じくらい速く、はるかに読みやすく、サポートしやすいことがわかると思います。
于 2009-07-20T19:37:52.253 に答える
0

コマンドラインから挿入を試みましたか? このリンクによると、構文は正しいようです。

于 2009-04-20T15:02:23.293 に答える
0

行リストを指定すると、複数の行を挿入してもうまくいかないことは確かです。この場合

(V,E,L,N,Q,B,S,P)

複数の行を挿入するには、テーブルの列のネイティブな順序で値を指定する必要があります。

SQL を次のように変更してみてください。

string query = "INSERT INTO TESTDB2.RG_Table values" +   
"('abc', 'def', '2009-03-27 12:01:19', 'ghi', 'jkl', NULL, NULL, NULL)," +
"('abc', 'def', '2009-03-27 12:01:19', 'ghi', 'jkl', NULL, NULL, NULL)"; 
于 2009-12-07T14:50:08.643 に答える