MySQL のパフォーマンスを最大化するために JDBC バッチ挿入を最適化するにはどうすればよいですか?
Dec 07, 2024 pm 01:38 PMJDBC バッチ挿入パフォーマンスの最適化
MySQL データベースに大量のデータを挿入するには、最適なパフォーマンスを確保するために効率的なバッチ処理が必要です。一度に 100 万件のレコードをバッチ挿入するのは合理的なように思えるかもしれませんが、このプロセスをさらに最適化する手法があります。
問題を理解する
提供されたコードはプリペアド ステートメントを使用しています。テーブルに値を挿入しますが、2 つのキーは利用しませんproperty:
- useServerPrepStmts: false に設定すると、MySQL はクライアントではなくサーバー上でステートメントを準備し、ネットワーク オーバーヘッドを削減します。
- rewriteBatchedStatements: true に設定すると、MySQL はバッチ処理されたステートメントを書き換えて、より効率的なステートメントを使用します。マルチステートメントの実行メソッド。
接続の最適化
これらの最適化を有効にするには、接続 URL で両方のプロパティを設定します。
Connection c = DriverManager.getConnection("jdbc:mysql://host:3306/db?useServerPrepStmts=false&rewriteBatchedStatements=true", "username", "password");
改造コード
これで最適化が行われると、更新されたコードは次のようになります。
try { // Disable auto-commit c.setAutoCommit(false); // Create a prepared statement String sql = "INSERT INTO mytable (xxx), VALUES(?)"; PreparedStatement pstmt = c.prepareStatement(sql); Object[] vals=set.toArray(); for (int i=0; i<vals.length; i++) { pstmt.setString(1, vals[i].toString()); pstmt.addBatch(); } // Execute the batch int [] updateCounts = pstmt.executeBatch(); System.out.append("inserted "+updateCounts.length); } catch (SQLException e) { e.printStackTrace(); }
結論
「useServerPrepStmts」プロパティと「rewriteBatchedStatements」プロパティを設定することで、バッチ挿入プロセスを大幅に短縮できます。最適化され、大量のデータの挿入に必要な経過時間が短縮されます。
以上がMySQL のパフォーマンスを最大化するために JDBC バッチ挿入を最適化するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

人気の記事

人気の記事

ホットな記事タグ

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Alter Tableステートメントを使用してMySQLのテーブルをどのように変更しますか?

Linuxでmysqlを実行します(phpmyAdminを使用してポッドマンコンテナを使用して/なし)

MACOSで複数のMySQLバージョンを実行する:ステップバイステップガイド

共通の脆弱性(SQLインジェクション、ブルートフォース攻撃)に対してMySQLを保護するにはどうすればよいですか?

MySQL接続用のSSL/TLS暗号化を構成するにはどうすればよいですか?
