gpt4 book ai didi

asp.net - 使用 DB2Command.ExecuteNonQuery 插入多行

转载 作者:行者123 更新时间:2023-12-02 18:49:22 24 4
gpt4 key购买 nike

我正在尝试使用如下 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();

谁能解释一下这是什么原因造成的?

最佳答案

我意识到这是一个非常古老的问题,但到目前为止,没有一个答案能够找到问题的真正根源。由于他不能使用多个 VALUES 子句,我猜测他使用的是 z/OS,而 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 时才会得到它,而且它们都会同时出现。

关于asp.net - 使用 DB2Command.ExecuteNonQuery 插入多行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/761543/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com