挑戦
私のアプリ (React Spring Boot Oracle) では、大規模なデータセットを処理すると、処理時間がイライラするほど遅くなりました。精度や完全性を損なうことなくパフォーマンスを向上させるソリューションが必要でした。
解決策: NTILE 並列処理
NTILE は、結果セットを指定された数のほぼ同じサイズのチャンク (「タイル」と呼ばれる) に分割するように設計された強力な SQL ウィンドウ関数です。各行には、順序付きセット内の位置に基づいてパーティション番号が割り当てられます。
NTILE を使用することで、クエリ結果を管理可能なチャンクに分割し、これらのパーティションを並列処理しました。このアプローチにより、データのフェッチと処理を同時に行うことができ、待ち時間が大幅に短縮されました。
これを実装する方法の実際的な例を次に示します。
WITH PartitionedSales AS ( SELECT sales_id, sales_amount, sales_date, NTILE(2) OVER (ORDER BY sales_id) AS partition_number -- Assigns a partition number (1 or 2) to each row FROM sales WHERE sales_date BETWEEN '2023-01-01' AND '2023-12-31' ) SELECT * FROM PartitionedSales WHERE partition_number = :partitionNumber -- Replace :partitionNumber with the actual partition number (1 or 2)
上記の SQL スニペットでは:
- NTILE(2) は、データを 2 つの等しいチャンクに分割し、sales_id に基づいて並べ替えます。
- 対応するパーティションからデータをフェッチするには、:partitionNumber を 1 または 2 に置き換えます。
フロントエンドでは、並列処理を使用して各パーティションを効率的にフェッチできます。
async function fetchPartition(partitionNumber) { const response = await fetch('/api/sales?partition=' + partitionNumber}); return response.json(); } async function fetchData() { try { const [partition1, partition2] = await Promise.all([ fetchPartition(1), // Fetch the first partition fetchPartition(2) // Fetch the second partition ]); // Combine and process results const combinedResults = [...partition1, ...partition2]; processResults(combinedResults); } catch (error) { console.error('Error fetching data:', error); } }
このコード内:
- fetchPartition は、特定のパーティションのデータを取得します。
- fetchData は両方のフェッチ操作を並行して実行し、結合された結果を処理します。
あなたにもできる方法
- 重いクエリを特定する: アプリの速度を低下させているクエリを見つけます。
- NTILE の適用: NTILE 関数を使用して、クエリ結果をより小さな部分に分割します。
- 並列処理: 同時タスクを処理するアプリの機能を利用して、これらの小さなクエリを並列実行します。
データ量の多いアプリケーションのパフォーマンスを向上させたい場合は、この方法を試してみてください。これは、クエリの実行時間を長くするのではなく、よりハードに実行するための賢明で効果的な方法です。
重要な考慮事項
同時リクエストを処理する場合、データベース接続の需要が大きくなる可能性があります。この接続の多用によりデータベースに負担がかかり、パフォーマンスのボトルネックが発生する可能性があります。データベースの応答性を維持し、効率的に実行できるようにするには、同時リクエストの数を監視および管理することが重要です。
以上がSQLクエリが遅い?このテクニックでアプリのパフォーマンスを向上させるの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

JavaScript文字列置換法とFAQの詳細な説明 この記事では、javaScriptの文字列文字を置き換える2つの方法について説明します:内部JavaScriptコードとWebページの内部HTML。 JavaScriptコード内の文字列を交換します 最も直接的な方法は、置換()メソッドを使用することです。 str = str.replace( "find"、 "置換"); この方法は、最初の一致のみを置き換えます。すべての一致を置き換えるには、正規表現を使用して、グローバルフラグGを追加します。 str = str.replace(/fi

このチュートリアルでは、カスタムGoogle検索APIをブログまたはWebサイトに統合する方法を示し、標準のWordPressテーマ検索関数よりも洗練された検索エクスペリエンスを提供します。 驚くほど簡単です!検索をyに制限することができます

それで、あなたはここで、Ajaxと呼ばれるこのことについてすべてを学ぶ準備ができています。しかし、それは正確には何ですか? Ajaxという用語は、動的でインタラクティブなWebコンテンツを作成するために使用されるテクノロジーのゆるいグループ化を指します。 Ajaxという用語は、もともとJesse Jによって造られました

この記事シリーズは、2017年半ばに最新の情報と新鮮な例で書き直されました。 このJSONの例では、JSON形式を使用してファイルに単純な値を保存する方法について説明します。 キー価値ペア表記を使用して、あらゆる種類を保存できます

楽なWebページレイアウトのためにjQueryを活用する:8本質的なプラグイン jQueryは、Webページのレイアウトを大幅に簡素化します。 この記事では、プロセスを合理化する8つの強力なjQueryプラグイン、特に手動のウェブサイトの作成に役立ちます

コアポイント これは通常、メソッドを「所有」するオブジェクトを指しますが、関数がどのように呼び出されるかに依存します。 現在のオブジェクトがない場合、これはグローバルオブジェクトを指します。 Webブラウザでは、ウィンドウで表されます。 関数を呼び出すと、これはグローバルオブジェクトを維持しますが、オブジェクトコンストラクターまたはそのメソッドを呼び出すとき、これはオブジェクトのインスタンスを指します。 call()、apply()、bind()などのメソッドを使用して、このコンテキストを変更できます。これらのメソッドは、与えられたこの値とパラメーターを使用して関数を呼び出します。 JavaScriptは優れたプログラミング言語です。数年前、この文はそうでした

jQueryは素晴らしいJavaScriptフレームワークです。ただし、他のライブラリと同様に、何が起こっているのかを発見するためにフードの下に入る必要がある場合があります。おそらく、バグをトレースしているか、jQueryが特定のUIをどのように達成するかに興味があるからです

この投稿は、Android、BlackBerry、およびiPhoneアプリ開発用の有用なチートシート、リファレンスガイド、クイックレシピ、コードスニペットをコンパイルします。 開発者がいないべきではありません! タッチジェスチャーリファレンスガイド(PDF) Desigの貴重なリソース


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

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

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

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