ホームページ >Java >&#&チュートリアル >JDBC での単一挿入とバッチ挿入: どちらの方法がより優れたパフォーマンスを提供しますか?
JDBC を使用したバッチ挿入の最適化
JDBC で有効になっているバッチ処理は、クエリを一括実行することでネットワーク遅延を大幅に削減します。ただし、効率に関して、開発者は、(単一の挿入ステートメントに結合するのではなく) 複数の個別の挿入を作成した方がパフォーマンスが向上するかどうか疑問に思うことがよくあります。
単一のバッチ挿入と結合されたバッチ挿入の評価
複数の挿入を単一のステートメントに折りたたむことは直感的に効率的であるように見えるかもしれませんが、必ずしもそうではありません。 JDBC バッチ処理は、個別の挿入ステートメントを 1 つのユニットとして処理し、それらをまとめてデータベースに送信して実行します。したがって、値の挿入方法はパフォーマンスに大きな影響を与えません。
バッチ挿入速度を向上させるためのヒント
サンプル コード
効率的なバッチ挿入を示す例は次のとおりです。
PreparedStatement ps = c.prepareStatement("INSERT INTO employees VALUES (?, ?)"); ps.setString(1, "John"); ps.setString(2,"Doe"); ps.addBatch(); ps.clearParameters(); ps.setString(1, "Dave"); ps.setString(2,"Smith"); ps.addBatch(); ps.clearParameters(); int[] results = ps.executeBatch();
以上がJDBC での単一挿入とバッチ挿入: どちらの方法がより優れたパフォーマンスを提供しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。