使用DB2Command.ExecuteNonQuery插入多行

时间:2009-04-17 18:06:10

标签: asp.net sql insert db2

我正在尝试使用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语法与我读过的elsewhere匹配,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 个答案:

答案 0 :(得分:1)

我意识到这是一个非常古老的问题,但到目前为止,没有一个答案能够解决问题的真正根源。由于他不能使用多个VALUES子句,我猜他会在z / OS上,这不支持。有关详细信息,请参阅my other answer here

但是,有一种替代方法,因为他似乎使用的是.NET,它是驱动程序的"Chaining" ability。这允许您批量处理多个插入/更新/删除,当您“结束”链时,驱动程序会立即发送所有语句。这是一些示例代码:

<!-- 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时获得它,并且它们都会立即出现。

答案 1 :(得分:0)

您是否尝试过insert thru命令行? Syntax seems to be correct as per this link

答案 2 :(得分:0)

您的语法看起来大致正确。

  • 是否适用于cli?
  • 你看过JDBC批量更新了吗?我认为你会发现它几乎一样快,并且更具可读性和可支持性。

答案 3 :(得分: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)";