序文 実際には、次のような問題に遭遇する可能性があります。特定のレコードの ID がわかっていて、そのレコードが ID でソートおよびページ分けされている場合に、そのレコードがどのページにあるかを判断する必要があります。今日の記事はあなたにアイデアを提供します。 具体的な実装方法を見てみましょう。 IDでページング位置を照会する ID に基づいてページング位置を照会するには、たとえば、ID が逆順に並べ替えられている場合、次の SQL を使用して、この ID より大きいレコードの数を照会できます。 id > 5 のユーザーから count(id) を選択します。 この例では、user はテーブル名と、一致させる 5 桁の ID です。当然、逆順にソートされているため、この ID より大きいレコードの数を見つけるだけで済みます。昇順でソートされている場合は、この ID より小さいレコードの数を見つけるだけで済みます。 カウント値を見つけた後、現在のレコードがどのページにあるかをどのように計算しますか? 以下は Java コードの例です。 ページサイズ = 10; // 上記の結果が count で、値が 11 であると仮定します 整数カウント = 11; // 現在のレコードのpageNumを計算します // モジュラスに 1 を加えて、現在のページ番号をページ 2 として取得します。int pageNum = count/pageSize + 1; // さらに特定のページ上の特定の位置を取得したい場合は、残りの部分、つまり2ページ目の最初のレコード(0から始まる)を取得できます。 int インデックス = count%ページサイズ; 多次元ソートと配置 上記の単純な ID によるソートは、比較的簡単に解決できます。レコードをソートする次元が ID だけではない場合はどうでしょうか。たとえば、最初に年齢で逆順にソートします。年齢が同じ場合は、ID で続いて逆順にソートします。基本的な SQL ステートメントは次のとおりです。 ユーザーから id、age を age desc、id desc で並べ替えて選択します。 この時点で、ID が 5、年齢が 18 のレコードがあることがわかります。複数条件の並べ替えでこのレコードの位置をどのように決定するのでしょうか。 まず、複数条件ソートの難しさは、年齢が同じ場合にあります。年齢が異なる場合は、「ID に基づいてページング位置を照会する」と同様に、次の SQL を使用して ID の位置を特定できます。 年齢が18を超えるユーザーからcount(id)を選択します。 この方法では、組み合わせたソート年齢が異なる場合に、このレコードの位置を照会できます。特定の位置のアルゴリズムは、最初のケースと同じです。 では、年齢を重ねた場合、どのように対処すればよいのでしょうか?もちろん、これは複雑な関連クエリやサブテーブル クエリを通じて実現できます。別の方法として、現在のユーザーと同じ年齢で ID が大きいレコードの数をクエリする方法もあります。 age = 18 かつ id > 5 のユーザーから count(id) を選択します。 上記では、年齢が同じで ID が 5 より大きいレコードを取得します。最初のステップと 2 番目のステップの統計結果を追加します。問題は、「ID に基づいてページング位置を照会する」という単純なモードに戻ったのか、それとも同じアルゴリズムで現在のレコードがどのページにあるかを計算できるのかということです。 このソリューションはデータベースを 2 回クエリしますが、インデックスが適切に確立されている場合は、関連クエリやサブクエリよりも便利で簡潔かつ効率的です。 まとめ 上記は、実際に同様の問題に遭遇したときの 2 つの考え方です。これらが皆さんの突破口となることを願っています。また、皆さんがより良い解決策を提供できることを願っています。 さて、以上がこの記事の全内容です。この記事の内容が皆さんの勉強や仕事に一定の参考学習価値を持つことを願っています。ご質問があれば、メッセージを残してコミュニケーションしてください。123WORDPRESS.COM をご愛顧いただきありがとうございます。 以下もご興味があるかもしれません:
|
<<: CentOS 7 で Python を 3.6.6 にアップグレードした後に発生する yum エラー問題の解決方法の概要
>>: ElementUI ページネーション コンポーネントの使い方 Vue でのページネーション
画像をプルする docker プル mysql完成した画像を見る Docker イメージイメージを介...
目次DOM処理配列方法要約するDOM処理DOM はドキュメントの構造化された表現を提供し、スクリプト...
会社の開発者がテスト環境で挿入ステートメントを実行すると、正常に実行されるまでに 10 秒以上かかり...
目次メモリプールの概要1. nginxデータ構造2. nginxはOSからスペースngx_creat...
IE6 での CSS 背景画像のちらつきバグ (IE6 の背景画像キャッシュの問題) IE6 は、背...
macにbrewを使ってphp56をインストールしたところ、 opensslがバージョン1.1だった...
アクセス数が増えると、MySQL データベースへの負荷が増大します。MySQL アーキテクチャを使用...
コンテナと呼ばれるものは、実際には親イメージに基づいて読み取りおよび書き込み可能なファイル階層を作成...
序文このプロジェクトでは円形のメニューが必要です。オンラインで検索しましたが、適切なものが見つからな...
目次混合継承の影響: 1. 継承Vue.extend メソッドプロパティを拡張する2. ミックスイ...
Linux に PHP7 をインストールするにはどうすればいいですか? 1. 依存パッケージをインス...
目次1. ソフトウェアとシステムイメージ2. 仮想マシンを作成する3. CentOS8をインストール...
この記事の例では、WeChatアプレットのシームレスなスクロールを実現するための具体的なコードを参考...
この記事では主に、オブジェクト内のフィールドを削除するための js の実装を紹介し、次のように共有し...
序文vue3 を使った例をいくつか書いてみましたが、Vue3 のコンポジション API はよく設計さ...