0

http://dev.mysql.com/doc/refman/5.5/en/connector-net-programming-prepared.html的示例代码中,有代码(每次都做:cmd.ExecuteNonQuery()在迭代中):

try
{
    conn.Open();
    cmd.Connection = conn;

    cmd.CommandText = "INSERT INTO myTable VALUES(NULL, @number, @text)";
    cmd.Prepare();

    cmd.Parameters.AddWithValue("@number", 1);
    cmd.Parameters.AddWithValue("@text", "One");

    for (int i=1; i <= 1000; i++)
    {
        cmd.Parameters["@number"].Value = i;
        cmd.Parameters["@text"].Value = "A string value";
        cmd.ExecuteNonQuery();
    }

}

为什么不是(做1次:cmd.ExecuteNonQuery()迭代后):

 try
    {
        conn.Open();
        cmd.Connection = conn;
        cmd.CommandText = "INSERT INTO myTable VALUES(NULL, @number, @text)";
        cmd.Prepare();
        for (int i=1; i <= 1000; i++)
        {
          cmd.Parameters.AddWithValue("@number", i);
          cmd.Parameters.AddWithValue("@text", "One");
        }
        cmd.ExecuteNonQuery();
    }
4

1 回答 1

1

您的代码示例不正确;thecmd.ExecuteNonQuery();实际上是在循环内。

这将使用不同的参数执行 1,000 次查询,而无需重新创建命令。

于 2012-10-04T20:58:15.000 回答