1. はじめにプログラムが 実際、 2. JDBCはストリーミングクエリを実装するストリーミング クエリは、JDBC の パブリック int execute(String sql, boolean isStreamQuery) は SQLException をスローします { 接続 conn = null; PreparedStatement stmt = null; 結果セット rs = null; 整数カウント = 0; 試す { //データベース接続を取得します。conn = getConnection(); if (isStreamQuery) { //ストリーミング クエリ パラメータを設定します。stmt = conn.prepareStatement(sql, ResultSet.TYPE_FORWARD_ONLY, ResultSet.CONCUR_READ_ONLY); stmt.setFetchSize(Integer.MIN_VALUE); } それ以外 { //通常のクエリ stmt = conn.prepareStatement(sql); } //クエリを実行して結果を取得します。rs = stmt.executeQuery(); // 結果を走査します while (rs.next ()) { System.out.println(rs.getString(1)); カウント++; } } キャッチ (SQLException e) { e.printStackTrace(); ついに 閉じる(stmt、rs、conn); } カウントを返します。 } 「PS」: 上記の例では、パラメーター 3. パフォーマンステストテスト用にテストテーブル
3.1. 大容量データの一般クエリをテストする@テスト パブリック void testCommonBigData() は SQLException をスローします { 文字列 sql = "select * from my_test"; テスト実行(sql, false); } 3.1.1. クエリ時間 27wのデータ量は38秒かかります 3.1.2. メモリ使用量 約1Gのメモリを使用 3.2. 大容量データストリーミングクエリのテスト@テスト パブリック void testStreamBigData() は SQLException をスローします { 文字列 sql = "select * from my_test"; テストを実行します(sql, true); } 3.2.1. クエリ時間 27wのデータ量は37秒かかります 3.2.2. メモリ使用量 バッチで取得されるため、メモリは30〜270mの間で変動します。 3.3. 少量データに対する通常のクエリのテスト@テスト パブリック void testCommonSmallData() は SQLException をスローします { 文字列 sql = "select * from my_test limit 100000, 10"; テスト実行(sql, false); } 3.3.1. クエリ時間 10個のデータには1秒かかります 3.4. 少量のデータでストリーミングクエリをテストする@テスト パブリック void testStreamSmallData() は SQLException をスローします { 文字列 sql = "select * from my_test limit 100000, 10"; テストを実行します(sql, true); } 3.4.1. クエリ時間 10個のデータには1秒かかります IV. 結論MySQL ストリーミング クエリはメモリ使用量に明らかな最適化効果をもたらしますが、クエリ速度にはほとんど影響しません。主に、大量のデータをクエリするときにメモリ使用量が高くなるシナリオを解決するために使用されます。 「デモアドレス」: https://github.com/zlt2000/mysql-stream-query これで、MySQL でストリーミング クエリを使用してデータ OOM を回避する方法に関するこの記事は終了です。MySQL ストリーミング クエリに関するより関連性の高いコンテンツについては、123WORDPRESS.COM で以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
>>: ログインボックスのメールプロンプトを実装するネイティブJS
目次1. beforeCreateとcreated関数2. beforeMountとmount関数3...
外部 CSS ファイルを使用したレンダリング パイプライン上図では、HTML データの要求から DO...
目次1 ストレステストの指標1.1 秒あたり1.2 クォータ1.3 平均処理時間(RT) 1.4 同...
1. nginx.conf の http{} に次のコードを追加します。 limit_conn_zo...
目次前面に書かれた要件分析 v1アイデア1: インターセプションメソッドを使用して入力ボックスの入力...
古典的な色の組み合わせは力と権威を伝え、強いロイヤルブルーはあらゆる古典的な色の組み合わせの中心的な...
導入mysql-utilities ツールセットは、DBA のツールボックスとも言えるさまざまなツー...
目次ショートポーリングロングポーリングウェブソケットコミュニケーションの原則シンプルな1対1チャット...
最初のステップ: VMwareで、「編集」-「仮想ネットワークエディタ」をクリックします。下図に示す...
この記事では、参考までにMYSQLログとバックアップとリストアについて紹介します。具体的な内容は以下...
この記事の例では、タイマー機能を実装するためのVueの具体的なコードを参考までに共有しています。具体...
この記事では、ソシュールの言語哲学などの理論に基づいて、CSS の class 属性は不要であると主...
目次概要方法1: params経由でパラメータを渡す方法2: クエリを通じてパラメータを渡す方法3:...
腹筋コマンドの原則Apache の ab コマンドは、マルチスレッドの同時リクエストをシミュレートし...
最近、データベースについて学び始めました。最初にやったことは、データベースとは何か、データベースとデ...