mysqlストアドプロシージャを使用してページング機能を実装する方法

PHPz
リリース: 2023-04-18 17:11:30
オリジナル
738 人が閲覧しました

開発では、データベースに対してページング クエリを実行する必要がよくあります。この機能を実装するにはさまざまな方法がありますが、ストアド プロシージャはより効率的で保守しやすい方法の 1 つです。この記事では、mysql ストアド プロシージャを使用してページング機能を実装する方法を紹介します。

  1. ストアド プロシージャの作成

まず、mysql でストアド プロシージャを作成し、ページング関数を実装する必要があります。基本的なストアド プロシージャの例を次に示します。

CREATE PROCEDURE `PageQuery`(
    IN pTableName VARCHAR(255),
    IN pSelectColumns VARCHAR(500),
    IN pWhere VARCHAR(500),
    IN pOrder VARCHAR(500),
    IN pStart INT,
    IN pPageSize INT,
    OUT totalRecord INT
)
BEGIN
    DECLARE sql CHAR(1000);
    SET sql = CONCAT('SELECT ',pSelectColumns,' FROM ',pTableName,' WHERE 1=1 ',pWhere,' ',pOrder,' LIMIT ',pStart,',',pPageSize);
    PREPARE stmt FROM sql;
    EXECUTE stmt;
    DEALLOCATE PREPARE stmt;
    SET sql = CONCAT('SELECT COUNT(1) FROM ',pTableName,' WHERE 1=1 ',pWhere);
    PREPARE stmt FROM sql;
    EXECUTE stmt INTO totalRecord;
    DEALLOCATE PREPARE stmt;
END
ログイン後にコピー
ログイン後にコピー

上記のストアド プロシージャのパラメータの説明は次のとおりです。

  • pTableName: クエリ対象のテーブルの名前
  • pSelectColumns: 問い合わせ対象のカラム名
  • pWhere: フィルタ条件
  • pOrder: ソート方法
  • pStart: 開始位置(ページ)
  • pPageSize : 各ページのサイズ
  • totalRecord: レコードの合計数

このストアド プロシージャは主に、指定されたページ番号と各ページのサイズのクエリ結果を返すために使用されます。フィルタリング条件を満たすレコードの総数として表示されます。

  1. ストアド プロシージャを使用する

ストアド プロシージャを使用してページング クエリを実装する手順は次のとおりです。

(1) ストアド プロシージャを呼び出す

CALL `PageQuery`(tableName, selectColumns, where, order, start, pageSize, totalRecord);
ログイン後にコピー

ストアド プロシージャを呼び出すときは、対応するパラメータを渡す必要があります。

(2) ページングデータの取得

上記の手順でストアドプロシージャを呼び出すと、指定したページ番号と各ページのサイズを持つクエリ結果が返されます。次のステートメントを使用してクエリ結果を取得できます。

SELECT * FROM temp_table;
ログイン後にコピー
ログイン後にコピー

(3) レコードの総数を取得します

ストアド プロシージャを呼び出すときに OUT パラメーター totalRecord を呼び出すと、レコードの総数を取得できます。フィルタリング条件を満たすレコードの総数。

次のフィールドを含むテスト テーブルがあるとします: id、name、age。

このテーブルに対して、ページごとに 10 個のデータを ID の降順に並べてページング クエリを実行する必要があります。

ストアド プロシージャを定義します:

CREATE PROCEDURE `PageQuery`(
    IN pTableName VARCHAR(255),
    IN pSelectColumns VARCHAR(500),
    IN pWhere VARCHAR(500),
    IN pOrder VARCHAR(500),
    IN pStart INT,
    IN pPageSize INT,
    OUT totalRecord INT
)
BEGIN
    DECLARE sql CHAR(1000);
    SET sql = CONCAT('SELECT ',pSelectColumns,' FROM ',pTableName,' WHERE 1=1 ',pWhere,' ',pOrder,' LIMIT ',pStart,',',pPageSize);
    PREPARE stmt FROM sql;
    EXECUTE stmt;
    DEALLOCATE PREPARE stmt;
    SET sql = CONCAT('SELECT COUNT(1) FROM ',pTableName,' WHERE 1=1 ',pWhere);
    PREPARE stmt FROM sql;
    EXECUTE stmt INTO totalRecord;
    DEALLOCATE PREPARE stmt;
END
ログイン後にコピー
ログイン後にコピー

ストアド プロシージャを呼び出します:

CALL `PageQuery`('test', 'id, name, age', '', 'ORDER BY id DESC', 0, 10, @totalRecord);
ログイン後にコピー

レコードの総数をクエリします:

SELECT @totalRecord;
ログイン後にコピー

クエリ結果を取得します:

SELECT * FROM temp_table;
ログイン後にコピー
ログイン後にコピー

上記の手順により、mysqlのページング機能を簡単に実装することができます。

概要:

Mysql ストアド プロシージャは、ページング クエリを実装する効率的で信頼性の高い方法です。ストアド プロシージャを定義し、対応するパラメータを渡すことで、ページング クエリ機能を簡単に実装できます。大量のページング クエリを必要とする一部のアプリケーション シナリオでは、ストアド プロシージャを使用するとクエリの効率が大幅に向上します。

以上がmysqlストアドプロシージャを使用してページング機能を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!