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
この記事では、画像テキストセグメンテーションを実装するためのNodeJSの具体的なコードを参考までに...
この記事では、Ubuntu 18.04でのVMware Toolsのインストールと設定について記録し...
目次最初の方法アプリ.vueホーム.vueホームコンテンツ.vueデータの応答性レスポンシブプロパテ...
1.vueパッケージングここでは、vueネイティブパッケージングコマンドを使用してvueプロジェクト...
1 公式サイトからMySQL8をダウンロードしてインストールするMySQL8 ダウンロードアドレスこ...
序文一般的なビジネス シナリオでは、検索ボックスへの入力が完了した後、検索データを取得するために関連...
1. 基本コンポーネントをインストールするまず、 yumコマンドを実行して、コードpullために必要...
目次使用シナリオ解決1. globalDataを使用して実装する2. ローカルキャッシュストレージを...
MySQL データベース インデックスが B+ ツリーを使用する理由をさらに分析する前に、データ構...
Vueはブール値でストレージを保存します今日、問題に遭遇しました。バックグラウンドから返された真偽の...
目次コンポーネント - タイムラインカスタムノードスタイルカスタムタイムスタンプコンポーネント - ...
プロジェクト要件では、アップロードされたドキュメントの前処理が必要です。ユーザーが doc 形式でド...
この記事では、画像を読み込むためのJavaScriptキャンバスの具体的なコードを参考までに紹介しま...
MySQL データベースの実行効率はプログラムの実行速度に大きな影響を与えます。データベースの効率的...
目次01 MySQLルーターの紹介MySQL Router とは何ですか? 02 MySQLルータの...