4.2.4. Создание хранимых процедур в Management Studio
Программа SQL Management Studio позволяет создавать хранимые процедуры при помощи встроенного шаблона. Для этого необходимо выбрать пункт выпадающего меню «Создать хранимую процедуру» для ветки «Программирование - Хранимые процедуры».
Генерируемый шаблон имеет следующий вид:
-- ======================================================
-- Template generated from Template Explorer using:
-- Create Procedure (New Menu).SQL
-- Use the Specify Values for Template Parameters
-- command (Ctrl-Shift-M) to fill in the parameter
-- values below.
--
-- This block of comments will not be included in
-- the definition of the procedure.
-- =====================================================
SET ANSI_NULLS ON
GO
SET QUOTEDJDENTIFIER ON
GO
-- =====================================================
-- Author: <Author,,Name>
-- Create date: <Create Date,,>
-- Description: <Description,,>
-- =====================================================
CREATE PROCEDURE <Procedure_Name, sysname, ProcedureName>
-- Add the parameters for the stored procedure here
<@Param1,sysname,@p1> <Datatype_For_Param1, ,int>=<Default_Value_For_Param1, , 0>,
<@Param2,sysname,@p2> <Datatype_For_Param2, ,int>=<Default_Value_For_Param2, , 0>
AS
BEGIN
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT ON;
-- Insert statements for procedure here
SELECT <@Param1, sysname, @p1>, <@Param2, sysname, @p2>
END
GO
В данном шаблоне выделяются следующие части:
- Общий комментарий, объясняющий происхождение шаблона
- Служебные команды
- Комментарий к процедуре, определяющий автора, дату создания и описание процедуры
- Оператор создания процедуры
- Определение параметров процедуры
- Определение текста процедуры
Созданные хранимые процедуры можно использовать при создании источника данных (рис. 45). Вид окна выбора местоположения данных для БД с одной хранимой процедурой приведен на рисунке 71.
Рис. 71. Использование хранимой процедуры в качестве источника данных