次の方法で共有


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

このトピックでは、SQL Server Management Studio および Transact-SQL の CREATE PROCEDURE ステートメントを使用して、Transact-SQL ストアド プロシージャを作成する方法について説明します。

アクセス許可

データベースの CREATE PROCEDURE 権限と、プロシージャを作成するスキーマに対する ALTER 権限が必要です。

ストアド プロシージャを作成する方法

次のいずれかを使用します。

SQL Server Management Studio を使用する

オブジェクト エクスプローラーでプロシージャを作成するには

  1. オブジェクト エクスプローラーで、データベース エンジンのインスタンスに接続し、そのインスタンスを展開します。

  2. Databases を展開し、AdventureWorks2012 データベースを展開してから、Programmability を展開します。

  3. [ストアド プロシージャ]を右クリックし、 [新しいストアド プロシージャ]をクリックします。

  4. [クエリ] メニューの [テンプレート パラメーターの値の指定] をクリックします。

  5. [テンプレート パラメーターの値の指定] ダイアログ ボックスで、各パラメーターに次の値を入力します。

    パラメーター
    作成者 名前
    作成日 今日の日付
    説明 従業員のデータが返されます。
    [Procedure_name] HumanResources.uspGetEmployeesTest
    [@Param1] @LastName
    [@Datatype_For_Param1] nvarchar(50)
    [Default_Value_For_Param1] NULL
    [@Param2] @FirstName
    [@Datatype_For_Param2] nvarchar(50)
    [Default_Value_For_Param2] NULL
  6. OK をクリックします。

  7. クエリ エディターで、SELECT ステートメントを次のステートメントに置き換えます。

    SELECT FirstName, LastName, Department  
    FROM HumanResources.vEmployeeDepartmentHistory  
    WHERE FirstName = @FirstName AND LastName = @LastName  
        AND EndDate IS NULL;  
    
  8. 構文をテストするには、 [クエリ] メニューの [解析]をクリックします。 エラー メッセージが返された場合は、ステートメントと上記の情報を比較し、必要に応じて修正します。

  9. プロシージャを作成するには、[クエリ] メニューの [実行] をクリックします。 プロシージャがデータベース内のオブジェクトとして作成されます。

  10. オブジェクト エクスプローラーにリストされたプロシージャを確認するには、 [ストアド プロシージャ] を右クリックして [更新]を選択します。

  11. プロシージャを実行するには、オブジェクト エクスプローラーでストアド プロシージャ名 HumanResources.uspGetEmployeesTest を右クリックし、 [ストアド プロシージャの実行]を選択します。

  12. [プロシージャの実行] ウィンドウでパラメーター @LastName の値に「Margheim」を、パラメーター @FirstName の値に「Diane」を入力します。

警告

すべてのユーザー入力を検証します。 ユーザー入力は検証するまで連結しないでください。 検証していないユーザー入力から作成されたコマンドは、絶対に実行しないでください。

Transact-SQL の使用

クエリ エディターでプロシージャを作成するには

  1. オブジェクト エクスプローラーで、 データベース エンジンのインスタンスに接続します。

  2. [ファイル] メニューの [新しいクエリ]をクリックします。

  3. 次の例をコピーしてクエリ ウィンドウに貼り付け、 [実行] をクリックします。 この例では、上と同じストアド プロシージャを別のプロシージャ名で作成します。

    USE AdventureWorks2012;  
    GO  
    CREATE PROCEDURE HumanResources.uspGetEmployeesTest2   
        @LastName nvarchar(50),   
        @FirstName nvarchar(50)   
    AS
    
        SET NOCOUNT ON;  
        SELECT FirstName, LastName, Department  
        FROM HumanResources.vEmployeeDepartmentHistory  
        WHERE FirstName = @FirstName AND LastName = @LastName  
        AND EndDate IS NULL;  
    GO
    
  4. プロシージャを実行するには、次の例をコピーして新しいクエリ ウィンドウに貼り付け、 [実行]をクリックします。 パラメーター値を指定するときに別の方法が表示されることに注意してください。

    EXECUTE HumanResources.uspGetEmployeesTest2 N'Ackerman', N'Pilar';  
    -- Or  
    EXEC HumanResources.uspGetEmployeesTest2 @LastName = N'Ackerman', @FirstName = N'Pilar';  
    GO  
    -- Or  
    EXECUTE HumanResources.uspGetEmployeesTest2 @FirstName = N'Pilar', @LastName = N'Ackerman';  
    GO
    

参照

CREATE PROCEDURE (Transact-SQL)