7.1. procedimientos almacenados

21

Upload: jorge-luis-lopez-m

Post on 14-Jan-2017

130 views

Category:

Education


8 download

TRANSCRIPT

Page 1: 7.1.  procedimientos almacenados
Page 2: 7.1.  procedimientos almacenados

Introducción a los procedimientos almacenados

Creación, ejecución, modificación y eliminación de procedimientos almacenados

Utilización de parámetros en los procedimientos almacenados

Ejecución de procedimientos almacenados extendidos

Control de mensajes de errorConsideraciones acerca del rendimiento

Page 3: 7.1.  procedimientos almacenados

Definición de procedimientos almacenadosProcesamiento inicial de los procedimientos

almacenados Procesamientos posteriores de los

procedimientos almacenadosVentajas de los procedimientos almacenados

Page 4: 7.1.  procedimientos almacenados

Los procedimientos almacenados no son un un comando especifico . Si no que son por lo general un grupo de comando e instrucciones

Para realizar una tarea especifica

Page 5: 7.1.  procedimientos almacenados

Se almacena en las tablassysobjects y syscomments

El plan compilado secoloca en la caché de

procedimientos

Compilación

Optimización

CreaciónCreación

EjecuciónEjecución(por primera vez (por primera vez o recompilación)o recompilación)

Análisis

Page 6: 7.1.  procedimientos almacenados

Plan de ejecución recuperado

Plan sin usar se retira

Plan de consulta Contexto de ejecución

SELECT *FROM dbo.memberWHERE member_no = ?

Conexión 1

8082

Conexión 2

Conexión 3

24

1003

Page 7: 7.1.  procedimientos almacenados

Compartir la lógica de la aplicaciónExposición de los detalles de las tablas de la

base de datosProporcionar mecanismos de seguridadMejorar el rendimientoReducir el tráfico de red

Page 8: 7.1.  procedimientos almacenados

Creación de procedimientos almacenadosRecomendaciones para la creación de

procedimientos almacenadosEjecución de procedimientos almacenadosModificación y eliminación de procedimientos

almacenados

Page 9: 7.1.  procedimientos almacenados

Utilice la instrucción CREATE PROCEDURE para crearlos en la base de datos activa

Puede anidar hasta 32 niveles Use sp_help para mostrar información

USE NorthwindGOCREATE PROC dbo.OverdueOrdersAS SELECT * FROM dbo.Orders WHERE RequiredDate < GETDATE() AND ShippedDate IS NullGO

Page 10: 7.1.  procedimientos almacenados

El usuario dbo debe ser el propietario de todos los procedimientos almacenados

Un procedimiento almacenado por tareaCrear, probar y solucionar problemasEvite sp_Prefix en los nombres de

procedimientos almacenadosUtilice la misma configuración de

conexión para todos los procedimientos almacenados

Reduzca al mínimo la utilización de procedimientos almacenados temporales

No elimine nunca directamente las entradas de Syscomments

Page 11: 7.1.  procedimientos almacenados

Ejecución de un procedimiento almacenado por separado

Ejecución de un procedimiento almacenado en una instrucción INSERT

EXEC OverdueOrders

INSERT INTO CustomersEXEC EmployeeCustomer

Page 12: 7.1.  procedimientos almacenados

Modificación de procedimientos almacenados Incluya cualquiera de las opciones en ALTER

PROCEDURE No afecta a los procedimientos almacenados

anidados

Eliminación de procedimientos almacenados Ejecute el procedimiento almacenado sp_depends

para determinar si los objetos dependen del procedimiento almacenado

USE NorthwindGOALTER PROC dbo.OverdueOrdersASSELECT CONVERT(char(8), RequiredDate, 1) RequiredDate, CONVERT(char(8), OrderDate, 1) OrderDate, OrderID, CustomerID, EmployeeID FROM OrdersWHERE RequiredDate < GETDATE() AND ShippedDate IS NullORDER BY RequiredDateGO

Page 13: 7.1.  procedimientos almacenados

Utilización de parámetros de entradaEjecución de procedimientos almacenados

con parámetros de entradaDevolución de valores mediante parámetros

de salidaVolver a compilar explícitamente

procedimientos almacenados

Page 14: 7.1.  procedimientos almacenados

Valide primero todos los valores de los parámetros de entrada

Proporcione los valores predeterminados apropiados e incluya las comprobaciones de NullCREATE PROCEDURE dbo.[Year to Year Sales]

@BeginningDate DateTime, @EndingDate DateTime ASIF @BeginningDate IS NULL OR @EndingDate IS NULLBEGIN RAISERROR('NULL values are not allowed', 14, 1) RETURNENDSELECT O.ShippedDate, O.OrderID, OS.Subtotal, DATENAME(yy,ShippedDate) AS YearFROM ORDERS O INNER JOIN [Order Subtotals] OS ON O.OrderID = OS.OrderIDWHERE O.ShippedDate BETWEEN @BeginningDate AND @EndingDateGO

Page 15: 7.1.  procedimientos almacenados

Paso de valores por el nombre del parámetro

Paso de valores por posiciónEXEC AddCustomer 'ALFKI2', 'Alfreds Futterkiste', 'Maria Anders', 'Sales Representative', 'Obere Str. 57', 'Berlin', NULL, '12209', 'Germany', '030-0074321'

EXEC AddCustomer @CustomerID = 'ALFKI', @ContactName = 'Maria Anders', @CompanyName = 'Alfreds Futterkiste', @ContactTitle = 'Sales Representative', @Address = 'Obere Str. 57', @City = 'Berlin', @PostalCode = '12209', @Country = 'Germany', @Phone = '030-0074321'

Page 16: 7.1.  procedimientos almacenados

CREATE PROCEDURE dbo.mathtutor@m1 smallint,

@m2 smallint,@result smallint OUTPUT

AS SET @result = @m1* @m2GODECLARE @answer smallintEXECUTE mathtutor 5, 6, @answer OUTPUTSELECT 'The result is: ' , @answer

The result is: 30

Resultados del Resultados del procedimientoprocedimientoalmacenadoalmacenado

Ejecución del Ejecución del procedimiento procedimiento almacenadoalmacenado

Creación del Creación del procedimiento procedimiento almacenadoalmacenado

Page 17: 7.1.  procedimientos almacenados

Volver a compilar cuandoEl procedimiento almacenado devuelve

conjuntos de resultados que varían considerablemente

Se agrega un nuevo índice a una tabla subyacente

El valor del parámetro es atípico Volver a compilar mediante

CREATE PROCEDURE [WITH RECOMPILE]EXECUTE [WITH RECOMPILE] sp_recompile

Page 18: 7.1.  procedimientos almacenados

Se programan con la API Servicios abiertos de datos

Pueden incluir características de C y C++Pueden contener múltiples funcionesSe pueden llamar desde un cliente o desde SQL

ServerSe pueden agregar sólo a la base de datos master

EXEC master..xp_cmdshell 'dir c:\'

Page 19: 7.1.  procedimientos almacenados

La instrucción RETURN sale incondicionalmente de una consulta o procedimiento

sp_addmessage crea mensajes de error personalizados

@@error contiene el número de error de la instrucción ejecutada más recientemente

Instrucción RAISERRORDevuelve un mensaje de error del sistema definido

por el usuarioEstablece un indicador del sistema para registrar

un error

Page 20: 7.1.  procedimientos almacenados

Demostración: Control de mensajes de error

Page 21: 7.1.  procedimientos almacenados

Monitor de sistema de Windows 2000Objeto: SQL Server: Administrador de cachéObjeto: Estadísticas de SQL

Analizador de SQLPuede supervisar eventosPuede probar cada instrucción en un

procedimiento almacenado