CREATE PROC dbo.ProcName AS SET NOCOUNT ON; --Procedure code here SELECT column1 FROM dbo.TblTable1 -- Reset SET NOCOUNT to OFF SET NOCOUNT OFF; GO
SELECT * FROM dbo.MyTable -- Preferred method -- Instead of SELECT * FROM MyTable -- Avoid this method --And finally call the stored procedure with qualified name like: EXEC dbo.MyProc -- Preferred method --Instead of EXEC MyProc -- Avoid this method
Si un nombre de procedimiento almacenado comienza con "sp_", a continuacin, busca el servidorSQL por primera vez en la base de datos maestra y luego en la base de datos actual perodo de sesiones. Bsqueda en la base de datos principal causa sobrecarga adicional e incluso un mal resultado si otro procedimiento almacenado con el mismo nombre se encuentra en la base de datos maestra.
El procedimiento almacenado sp_executesql admite parmetros. Por lo tanto, utilizando el procedimiento almacenado sp_executesql en lugar de la instruccin EXECUTE mejorar lareutilizacin de cdigo. El plan de ejecucin de una instruccin dinmica puede ser reutilizado slo si todos y cada personaje, incluido el caso, el espacio, los comentarios y los parmetros, es el mismo para dos estados. Por ejemplo, si ejecuta el lote a continuacin:
DECLARE @Query VARCHAR(100) DECLARE @Age INT SET @Age = 25 SET @Query = 'SELECT * FROM dbo.tblPerson WHERE Age = ' +CONVERT(VARCHAR(3),@Ag e) EXEC (@Query) Si volvemos a ejecutar el lote anterior con un valor diferente edad @, entonces el plan de ejecucin de sentencia SELECT creado por @ Edad = 25 no se pueden reutilizar. Sin embargo, si escribimos el lote de arriba como se indica a continuacin,
DECLARE @Query NVARCHAR(100) SET @Query = N'SELECT * FROM dbo.tblPerson WHERE Age = @Age' EXECUTE sp_executesql @Query, N'@Age int', @Age = 25 el plan compilado de esta sentencia SELECT se puede reutilizar para diferentes valores del parmetro @ Edad. La reutilizacin del plan existente cumplimiento dar lugar a un mejor desempeo.
Trate de evitar el uso de cursores de SQL Server siempre que sea posible:
El cursor utiliza una gran cantidad de recursos para la carga de procesamiento para mantener la posicin del registro actual en un conjunto de registros y esto disminuye el rendimiento. Sitenemos que procesar los registros uno por uno en un bucle, entonces debemos utilizar la clusula WHILE. Siempre que sea posible, se debe reemplazar el enfoque basado en cursor con SET enfoque. Debido a que el motor de SQL Server est diseada y optimizada para llevar a cabobasado en conjuntos operacin muy rpida. Una vez ms, por favor, tenga en cuenta el cursor estambin una especie de bucle while.
Antes de cdigos de SQL Server versin 2005 para el tratamiento de errores, hubo una gran porcin de cdigo en s, porque una declaracin de comprobacin de errores fue escrito despus de cada sentencia T-SQL. Ms cdigo siempre consume ms recursos y tiempo. En SQL Server 2005, una manera sencilla se introduce una nueva con el mismo propsito. La sintaxis es la siguiente:
BEGIN TRY --Your t-sql code goes here END TRY BEGIN CATCH --Your error handling code goes here END CATCH