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

あなたのコード サンプルは正しくありません。これcmd.ExecuteNonQuery();は実際にはループ内にあります。

これにより、コマンドを再作成せずに、さまざまなパラメーターを使用してクエリを 1,000 回実行します。

于 2012-10-04T20:58:15.000 に答える