公開ニュースグループでよく寄せられる質問は、「ストアド プロシージャに渡されたパラメータに基づいて並べ替えられた出力を返すにはどうすればよいですか?」です。高度な資格を持つ専門家の協力を得て、この問題に対するいくつかの解決策をまとめました。
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 つ) を変更する必要があることです。