Что такое хранимая процедура? - PullRequest
271 голосов
/ 20 января 2009

Что такое хранимая процедура? Как они работают? Каков состав хранимой процедуры (каждая вещь должна должна быть хранимой процедурой)?

Ответы [ 16 ]

220 голосов
/ 20 января 2009

Хранимые процедуры - это пакет операторов SQL, которые можно выполнить несколькими способами. Большинство основных СУБД поддерживают хранимые процедуры; однако не все так делают. Вам нужно будет проверить с вашей конкретной справочной документацией СУБД для специфики. Поскольку я больше всего знаком с SQL Server, я буду использовать его в качестве примера.

Чтобы создать хранимую процедуру, синтаксис достаточно прост:

CREATE PROCEDURE <owner>.<procedure name>

     <Param> <datatype>

AS

     <Body>

Так, например:

CREATE PROCEDURE Users_GetUserInfo

    @login nvarchar(30)=null

AS

    SELECT * from [Users]
    WHERE ISNULL(@login,login)=login

Преимущество хранимых процедур заключается в том, что вы можете централизовать логику доступа к данным в одном месте, которое затем легко оптимизировать администраторам баз данных. Хранимые процедуры также имеют преимущество в плане безопасности, поскольку вы можете предоставлять права на выполнение хранимой процедуры, но пользователю не нужно иметь разрешения на чтение / запись для базовых таблиц. Это хороший первый шаг против внедрения SQL.

Хранимые процедуры имеют свои недостатки, в основном это обслуживание, связанное с вашей базовой операцией CRUD . Допустим, для каждой таблицы у вас есть Вставка, Обновление, Удаление и хотя бы один выбор на основе первичного ключа, это означает, что в каждой таблице будет 4 процедуры. Теперь возьмите базу данных достойного размера из 400 таблиц, и у вас будет 1600 процедур! И это при условии, что у вас нет дубликатов, которые у вас, вероятно, будут.

Здесь использование ORM или какого-либо другого метода для автоматической генерации базовых операций CRUD имеет массу достоинств.

139 голосов
/ 13 июня 2013

Хранимая процедура - это набор предварительно скомпилированных операторов SQL, которые используются для выполнения специальной задачи.

Пример: если у меня есть Employee таблица

Employee ID  Name       Age  Mobile
---------------------------------------
001          Sidheswar  25   9938885469
002          Pritish    32   9178542436

Сначала я получаю таблицу Employee:

Create Procedure Employee details
As
Begin
    Select * from Employee
End

Чтобы запустить процедуру на SQL Server:

Execute   Employee details

--- (Employee details is a user defined name, give a name as you want)

Затем, во-вторых, я вставляю значение в таблицу сотрудников

Create Procedure employee_insert
    (@EmployeeID int, @Name Varchar(30), @Age int, @Mobile int)
As
Begin
    Insert Into Employee
    Values (@EmployeeID, @Name, @Age, @Mobile)
End

Чтобы запустить параметризованную процедуру на SQL Server:

Execute employee_insert 003,’xyz’,27,1234567890

  --(Parameter size must be same as declared column size)

Пример: @Name Varchar(30)

В таблице Employee размер столбца Name должен быть varchar(30).

72 голосов
/ 09 апреля 2014

Хранимая процедура - это группа операторов SQL, которая была создана и сохранена в базе данных. Хранимая процедура будет принимать входные параметры, поэтому несколько клиентов могут использовать одну и ту же процедуру по сети, используя разные входные данные. Хранимые процедуры уменьшат сетевой трафик и увеличат производительность. Если мы изменим хранимую процедуру, все клиенты получат обновленную хранимую процедуру.

Пример создания хранимой процедуры

CREATE PROCEDURE test_display
AS
    SELECT FirstName, LastName
    FROM tb_test;

EXEC test_display;

Преимущества использования хранимых процедур

  • Хранимая процедура позволяет выполнять модульное программирование.

    Вы можете создать процедуру один раз, сохранить ее в базе данных и вызывать ее любое количество раз в вашей программе.

  • Хранимая процедура обеспечивает более быстрое выполнение.

    Если операция требует большого количества кода SQL, который выполняется многократно, хранимые процедуры могут быть быстрее. Они анализируются и оптимизируются при первом запуске, и скомпилированная версия хранимой процедуры остается в кеше памяти для дальнейшего использования. Это означает, что хранимая процедура не нуждается в повторном анализе и повторной оптимизации при каждом использовании, что приводит к гораздо более быстрому времени выполнения.

  • Хранимая процедура может уменьшить сетевой трафик.

    Операция, требующая сотен строк кода Transact-SQL, может быть выполнена с помощью одного оператора, выполняющего код в процедуре, а не путем отправки сотен строк кода по сети.

  • Хранимые процедуры обеспечивают лучшую безопасность ваших данных

    Пользователям может быть предоставлено разрешение на выполнение хранимой процедуры, даже если у них нет разрешения на непосредственное выполнение инструкций процедуры.

    В SQL Server у нас есть различные типы хранимых процедур:

    • Системные хранимые процедуры
    • Пользовательские хранимые процедуры
    • Расширенные хранимые процедуры
  • Системные * хранимые процедуры сохраняются в базе данных master и начинаются с префикса sp_. Эти процедуры могут использоваться для выполнения различных задач по поддержке функций SQL Server для вызовов внешних приложений в системных таблицах

    Пример: sp_helptext [StoredProcedure_Name]

  • Пользовательские хранимые процедуры обычно хранятся в пользовательской базе данных и, как правило, предназначены для выполнения задач в пользовательской базе данных. При кодировании этих процедур не используйте префикс sp_, потому что если мы сначала используем префикс sp_, он проверит базу данных master, а затем перейдет к пользовательской базе данных. 1060 *

  • Расширенные хранимые процедуры - это процедуры, вызывающие функции из файлов DLL. В настоящее время расширенные хранимые процедуры не рекомендуется использовать по той причине, что было бы лучше избегать использования расширенных хранимых процедур.

34 голосов
/ 20 января 2009

Обычно хранимая процедура - это «функция SQL». У них есть:

-- a name
CREATE PROCEDURE spGetPerson
-- parameters
CREATE PROCEDURE spGetPerson(@PersonID int)
-- a body
CREATE PROCEDURE spGetPerson(@PersonID int)
AS
SELECT FirstName, LastName ....
FROM People
WHERE PersonID = @PersonID

Это пример, ориентированный на T-SQL. Хранимые процедуры могут выполнять большинство операторов SQL, возвращать скалярные и табличные значения и считаются более безопасными, поскольку они предотвращают атаки с использованием SQL-инъекций.

14 голосов
/ 22 мая 2016

Подумайте о такой ситуации,

  • У вас есть база данных с данными.
  • Для доступа к этой центральной базе данных требуется ряд различных приложений, а в будущем появятся и новые приложения.
  • Если вы собираетесь вставлять запросы встроенной базы данных для доступа к центральной базе данных, внутри кода каждого приложения по отдельности, то, вероятно, вам придется повторять один и тот же запрос снова и снова внутри кода разных приложений.
  • В такой ситуации вы можете использовать хранимые процедуры (SP). С помощью хранимых процедур вы пишете несколько общих запросов (процедур) и сохраняете их в центральной базе данных.
  • Теперь дублирование работы никогда не произойдет, как раньше, и доступ к данным и обслуживание будут осуществляться централизованно.

Примечание:

  • В описанной выше ситуации вы можете задаться вопросом: «Почему мы не можем ввести центральный сервер доступа к данным для взаимодействия со всеми приложениями? Да. Это будет возможной альтернативой. Но,
  • Основным преимуществом SP по сравнению с этим подходом является то, что в отличие от вашего кода доступа к данным со встроенными запросами, SP - это предварительно скомпилированные операторы, поэтому они будут выполняться быстрее. А расходы на связь (по сетям) будут как минимум.
  • В противоположность этому, SP будут увеличивать нагрузку на сервер базы данных. Если это будет проблемой в зависимости от ситуации, лучшим выбором будет сервер централизованного доступа к данным со встроенными запросами.
7 голосов
/ 21 августа 2013

Хранимая процедура в основном используется для выполнения определенных задач в базе данных. Например

  • Получить наборы результатов базы данных из некоторой бизнес-логики данных.
  • Выполнение нескольких операций с базой данных за один вызов.
  • Используется для переноса данных из одной таблицы в другую.
  • Может вызываться для других языков программирования, например Java.
5 голосов
/ 28 декабря 2015

Хранимая процедура - это не что иное, как группа операторов SQL, скомпилированных в один план выполнения.

  1. Создать один раз и назвать его n раз
  2. Снижает сетевой трафик

Пример: создание хранимой процедуры

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE PROCEDURE GetEmployee
      @EmployeeID int = 0
AS
BEGIN
      SET NOCOUNT ON;

      SELECT FirstName, LastName, BirthDate, City, Country
      FROM Employees 
      WHERE EmployeeID = @EmployeeID
END
GO

Изменить или изменить хранимую процедуру:

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO

ALTER PROCEDURE GetEmployee
      @EmployeeID int = 0
AS
BEGIN
    SET NOCOUNT ON;

    SELECT FirstName, LastName, BirthDate, City, Country
    FROM Employees 
    WHERE EmployeeID = @EmployeeID
END
GO

Удалить или удалить хранимую процедуру:

DROP PROCEDURE GetEmployee
5 голосов
/ 19 декабря 2013

Хранимая процедура используется для извлечения данных, изменения данных и удаления данных в таблице базы данных. Вам не нужно писать целую команду SQL каждый раз, когда вы хотите вставить, обновить или удалить данные в базе данных SQL.

3 голосов
/ 15 августа 2017

«Что такое хранимая процедура» уже есть ответы в других постах здесь. То, что я опубликую, является одним из менее известных способов использования хранимых процедур. Это grouping stored procedures или numbering stored procedures.

Синтаксическая ссылка

enter image description here

; number согласно это

Необязательное целое число, которое используется для группировки процедур с одинаковыми именами. Эти сгруппированные процедуры могут быть сброшены вместе с помощью одного оператора DROP PROCEDURE

* ** 1023 тысяча двадцать-дв * Пример
CREATE Procedure FirstTest 
(
    @InputA INT
)
AS 
BEGIN
    SELECT 'A' + CONVERT(VARCHAR(10),@InputA)
END
GO

CREATE Procedure FirstTest;2
(
    @InputA INT,
    @InputB INT
)
AS 
BEGIN
    SELECT 'A' + CONVERT(VARCHAR(10),@InputA)+ CONVERT(VARCHAR(10),@InputB)
END
GO

Использование

exec FirstTest 10
exec FirstTest;2 20,30

Результат

enter image description here

Еще одна попытка

CREATE Procedure SecondTest;2
(
     @InputA INT,
    @InputB INT
)
AS 
BEGIN
    SELECT 'A' + CONVERT(VARCHAR(10),@InputA)+ CONVERT(VARCHAR(10),@InputB)
END
GO

Результат

Сообщение 2730, Уровень 11, Состояние 1, Процедура SecondTest, Строка 1 [Стартовая Строка 3] Невозможно создать процедуру «SecondTest» с номером группы 2, потому что процедура с тем же именем и номером группы 1 в настоящее время не существует в базе данных. Необходимо выполнить CREATE PROCEDURE 'SecondTest'; сначала 1.

Ссылки

  1. CREATE PROCEDURE с синтаксисом числа
  2. Нумерованные хранимые процедуры в SQL Server - techie-friendly.blogspot.com
  3. Группировка хранимых процедур - sqlmag

ВНИМАНИЕ

  1. После того, как вы сгруппируете процедуры, вы не сможете удалить их по отдельности.
  2. Эта функция может быть удалена в будущей версии Microsoft SQL Server.
3 голосов
/ 31 мая 2016
  • Хранимая процедура - это предварительно скомпилированный набор из одного или нескольких операторов SQL, которые выполняют определенную задачу.

  • Хранимая процедура должна выполняться отдельно, используя EXEC

  • Хранимая процедура может возвращать несколько параметров

  • Хранимая процедура может использоваться для реализации транзакции

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...