ホームページ > バックエンド開発 > PHPチュートリアル > データベースクエリ結果の動的ソート(1)_PHPチュートリアル

データベースクエリ結果の動的ソート(1)_PHPチュートリアル

WBOY
リリース: 2016-07-13 17:01:34
オリジナル
1298 人が閲覧しました

公開ニュースグループでよく寄せられる質問は、「ストアド プロシージャに渡されたパラメータに基づいて並べ替えられた出力を返すにはどうすればよいですか?」です。高度な資格を持つ専門家の協力を得て、この問題に対するいくつかの解決策をまとめました。
1. IF...ELSE を使用して、事前に作成されたクエリを実行します。
ほとんどの人にとって、最初に思い浮かぶのは、IF...ELSE ステートメントを使用して、事前に作成されたいくつかのクエリの 1 つを実行することです。たとえば、Northwind データベースにクエリを実行して、並べ替えられた配送業者のリストを取得するとします。呼び出しコードではストアド プロシージャ パラメーターの形式で列を指定し、ストアド プロシージャはこの列に基づいて出力結果を並べ替えます。リスト 1 は、そのようなストアド プロシージャ (GetSortedShippers ストアド プロシージャ) の可能な実装の 1 つを示しています。
[リスト 1: IF...ELSE を使用して、事前に作成された複数のクエリの 1 つを実行する]
CREATE PROC GetSortedShippers
@OrdSeq AS int
AS
IF @OrdSeq = 1
SELECT * FROM Shippers ORDER BY ShipperID
ELSE IF @OrdSeq = 2
SELECT * FROM Shippers ORDER BY CompanyName
ELSE IF @OrdSeq = 3
SELECT * FROM Shippers ORDER BY Phone

この方法の利点は、コードが非常にシンプルで分かりやすいことと、SQLのクエリオプティマイザーであることです。サーバー 各 SELECT クエリのクエリ最適化計画を作成して、コードの最適なパフォーマンスを確保する機能。このアプローチの主な欠点は、クエリ要件が変更された場合に、複数の独立した SELECT クエリ (この場合は 3 つ) を変更する必要があることです。

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/631158.html技術記事公開ニュースグループでよく寄せられる質問は、「ストアド プロシージャに渡されたパラメータに基づいて並べ替えられた出力を返すにはどうすればよいですか?」です。ハイレベルの専門家の協力を得て...
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート