ホームページ >データベース >mysql チュートリアル >データ管理を高速化するために MySQL の行挿入を最適化するにはどうすればよいですか?

データ管理を高速化するために MySQL の行挿入を最適化するにはどうすればよいですか?

Mary-Kate Olsen
Mary-Kate Olsenオリジナル
2024-12-03 17:56:11778ブラウズ

How Can I Optimize MySQL Row Insertion for Faster Data Management?

MySQL データベースへの行挿入の最適化

MySQL データベースへの行挿入のパフォーマンスは、効率的なデータ管理にとって重要です。個別の挿入クエリを使用する従来の方法では時間がかかる場合があります。ここでは、挿入プロセスを大幅に高速化する高度に最適化されたアプローチを紹介します。

この改良された方法では、多数の個別の INSERT ステートメントを実行する代わりに、単一の複数行の INSERT ステートメントを利用して複数の行を同時に挿入します。繰り返しのオーバーヘッドを回避し、挿入する大量のデータのバッチを作成することにより、データベースは操作をより効率的に処理できます。

以下のコードは、この手法を示しています。

public static void BulkToMySQL()
{
    string ConnectionString = "server=192.168.1xxx";
    StringBuilder sCommand = new StringBuilder("INSERT INTO User (FirstName, LastName) VALUES ");
    
    using (MySqlConnection mConnection = new MySqlConnection(ConnectionString))
    {
        List<string> Rows = new List<string>();
        for (int i = 0; i < 100000; i++)
        {
            Rows.Add(string.Format("('{0}','{1}')", MySqlHelper.EscapeString("test"), MySqlHelper.EscapeString("test")));
        }
        sCommand.Append(string.Join(",", Rows));
        sCommand.Append(";");
        mConnection.Open();
        
        using (MySqlCommand myCmd = new MySqlCommand(sCommand.ToString(), mConnection))
        {
            myCmd.CommandType = CommandType.Text;
            myCmd.ExecuteNonQuery();
        }
    }
}

このメソッドを利用することにより、 100,000 行の挿入は 3 秒 以内に完了でき、元の 40 秒から大幅に改善されました。以下に示すように、生成された SQL ステートメントは、単一ステートメントへの複数行の挿入を示しています。

INSERT INTO User (FirstName, LastName) VALUES ('test','test'),('test','test'),... ;

データの整合性を確保し、コード インジェクション攻撃を防ぐために、MySqlHelper.EscapeString メソッドを使用して特殊文字をエスケープします。挿入されたデータ内。

以上がデータ管理を高速化するために MySQL の行挿入を最適化するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。