MySQL クエリにおけるページングのアイデアの最適化
mysql|ページネーション|最適化
著者: steeven
ページングについて議論している人はほとんどいないようですが、皆さんは、limit m,n に夢中ですか?
インデックス作成の場合は、limit m,n で十分高速ですが、複雑な条件で検索する場合は、
何かが見つかりません。 order by somefield+somefield
mysql はデータベースを検索し、条件を満たす「すべて」のレコードを見つけて、m,n 個のレコードを取り出します。
データ量が数十万で、ユーザーが非常に人気のある単語を検索する場合、
昔の夢を追体験するために最後の数ページを読まなければなりません。 。 。 Mysql は非常に悲惨な状況になり、ハードディスクを操作し続ける必要があります。
そこで、mysql にページングも保存させてみることができます。もちろん、プログラムは連携する必要があります。
(これは単なるアイデアです。皆さんも議論してください)
ASP ページング: ASP システムには、ページングを実装するための Recordset オブジェクトがありますが、大量のデータがメモリに配置されるため、いつ有効期限が切れるかはわかりません (ASP 専門家にお願いします
ガイダンス)。
SQL データベース ページング: ストアド プロシージャとカーソルを使用したページング。
必要な結果を取得するために 1 つのクエリを使用する場合を想像してください。 ID が設定されているため、後続のページが必要な場合は、結果の ID に従って関連するレコードを読み出します。この方法では、このクエリのすべての ID を保持するのに必要なスペースはわずかです (クエリ結果は SQL ですが、期限切れのガベージをクリアする方法がわかりません?)
この方法で、mysql はストレージ ページング メカニズムをシミュレートできます。 :
1. select id from $table where $condition order by $field limit $max_pages*$count;
条件を満たす ID をクエリします。
条件を満たすレコードの最大数を制限するか、追加しません。
2. PHP のすべての変数は実行後に失われるため、次のことを検討できます:
オプション a. mysql で一時テーブルを作成し、一意の識別子として時刻または乱数を使用してクエリ結果を挿入します。
page1~pagen フィールドを作成します。各フィールドは、1 つの ID が 1 つのレコードに対応するように、ページに必要な ID を保存します。ファイルを保存します。
$IDs 配列 $IDs[1]~$IDs[$max_pages] を作成します。ユーザーが同時に複数の
ウィンドウを開いてクエリを実行する場合があることを考慮して、クエリを回避するために $ids に一意のマークを付ける必要があります。相互に上書きした結果です。 2 次元配列
と $$var はどちらも良いアイデアです。
3. 各ページのリクエストで、「,」で区切られた対応する ID を直接見つけます。
select * from $table where id in ($ids); 速度は非常に高速です
4.結果は自動クリアとみなされる必要があります。タイマーを設定するか、比例してランダムにクリアすることができます。 mysql 一時テーブルを使用する場合は、タイムスタンプフィールドを追加する必要があり、一定期間操作されなかった場合はセッションに $IDs["time"]=time() を追加します。期限切れデータとして。
5. 最適化したい場合は、1 と 2.a のステートメントを select... into ....にマージすることを検討してください。
注:
1. 上記は単なる mysql のパッチ適用ソリューションです。 mysql はいつこれらの機能を追加しますか? 2. 他のデータベースにも適用できます。
3. 他のデータベースにさらに高度なページング方法がある場合は、私に知らせるか、steeven@kali.com.cn にメールしてください。
4. クエリするデータが本当にたくさんある場合は、SQL と Oracle の両方が提供する mysql に別れを告げてください。より高度なキーワード インデックス クエリ。
卓越性を目指して、上記は単なる紹介にすぎません。ページネーションの問題について一緒に議論することを歓迎します。 (他のデータベースに関するものでも構いません)
いつか、初心者向けにさまざまなページング方法が整理されて参考になることを願っています。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

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

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック











WebアプリケーションにおけるMySQLの主な役割は、データを保存および管理することです。 1.MYSQLは、ユーザー情報、製品カタログ、トランザクションレコード、その他のデータを効率的に処理します。 2。SQLクエリを介して、開発者はデータベースから情報を抽出して動的なコンテンツを生成できます。 3.MYSQLは、クライアントサーバーモデルに基づいて機能し、許容可能なクエリ速度を確保します。

Laravelは、Webアプリケーションを簡単に構築するためのPHPフレームワークです。次のような強力な機能を提供します。インストール:Laravel CLIを作曲家にグローバルにインストールし、プロジェクトディレクトリにアプリケーションを作成します。ルーティング:ルート/web.phpのURLとハンドラーの関係を定義します。ビュー:リソース/ビューでビューを作成して、アプリケーションのインターフェイスをレンダリングします。データベース統合:MySQLなどのデータベースとのすぐ外側の統合を提供し、移行を使用してテーブルを作成および変更します。モデルとコントローラー:モデルはデータベースエンティティを表し、コントローラーはHTTP要求を処理します。

MySQLとPHPMyAdminは、強力なデータベース管理ツールです。 1)MySQLは、データベースとテーブルを作成し、DMLおよびSQLクエリを実行するために使用されます。 2)PHPMyAdminは、データベース管理、テーブル構造管理、データ操作、ユーザー許可管理のための直感的なインターフェイスを提供します。

小さなアプリケーションを開発する際には、軽量データベース操作ライブラリをすばやく統合する必要性という厄介な問題に遭遇しました。複数のライブラリを試した後、私はそれらがあまりにも多くの機能を持っているか、あまり互換性がないかのどちらかであることがわかりました。最終的に、私は問題を完全に解決したYii2に基づいた単純化されたバージョンであるMinii/DBを見つけました。

他のプログラミング言語と比較して、MySQLは主にデータの保存と管理に使用されますが、Python、Java、Cなどの他の言語は論理処理とアプリケーション開発に使用されます。 MySQLは、データ管理のニーズに適した高性能、スケーラビリティ、およびクロスプラットフォームサポートで知られていますが、他の言語は、データ分析、エンタープライズアプリケーション、システムプログラミングなどのそれぞれの分野で利点があります。

記事の概要:この記事では、Laravelフレームワークを簡単にインストールする方法について読者をガイドするための詳細なステップバイステップの指示を提供します。 Laravelは、Webアプリケーションの開発プロセスを高速化する強力なPHPフレームワークです。このチュートリアルは、システム要件からデータベースの構成とルーティングの設定までのインストールプロセスをカバーしています。これらの手順に従うことにより、読者はLaravelプロジェクトのための強固な基盤を迅速かつ効率的に築くことができます。

MySQLの基本操作には、データベース、テーブルの作成、およびSQLを使用してデータのCRUD操作を実行することが含まれます。 1.データベースの作成:createdatabasemy_first_db; 2。テーブルの作成:createTableBooks(idintauto_incrementprimarykey、titlevarchary(100)notnull、authorvarchar(100)notnull、published_yearint); 3.データの挿入:InsertIntoBooks(タイトル、著者、公開_year)VA

MySQLは、テーブル構造とSQLクエリを介して構造化されたデータを効率的に管理し、外部キーを介してテーブル間関係を実装します。 1.テーブルを作成するときにデータ形式と入力を定義します。 2。外部キーを使用して、テーブル間の関係を確立します。 3。インデックス作成とクエリの最適化により、パフォーマンスを改善します。 4.データベースを定期的にバックアップおよび監視して、データのセキュリティとパフォーマンスの最適化を確保します。
