SQL Server no tiene función que puede recortar espacios inicial o finales de cualquier cadena al mismo tiempo. SQL tienen LTRIM() y RTRIM() que puede recortar espacios iniciales y finales respectivamente. SQL Server 2008 también no tiene función TRIM(). Usuario puede fácilmente utilizar LTRIM() y RTRIM() juntos y simular la funcionalidad TRIM().
SELECT RTRIM(LTRIM(' Word ')) AS Answer;
Debe dar resultado sin espacios inicial o finales.Respuesta
Word
He creado tras UDF que todos los días cuando tengo a TRIM() cualquier palabra o columna.
CREATE FUNCTION dbo.TRIM(@string VARCHAR(MAX))
RETURNS VARCHAR(MAX)
BEGIN
RETURN LTRIM(RTRIM(@string))
END
GO
Ahora déjenos probar por encima de la UDF, ejecuta la siguiente declaración donde hay iniciales y espacios alrededor de palabra.
SELECT dbo.TRIM(' leading trailing ')
Devolverá la cadena en la ventana de resultado como'leading trailing'
No habrá ningún espacio a su alrededor. Si espacios adicionales son datos inútiles, cuando se insertan datos en la base de datos debe recortarse. Si hay necesitamos de espacios en los datos, pero en algunos casos deben recortarse al recuperar nos puede utilizar columnas calculadas. Leer más sobre columnas SQL SERVER – Puzzle – solución – calcula explicación de tipo de datos de columnas calculadas.
El ejemplo siguiente muestra las columnas calculadas cómo puede utilizarse para recuperar datos recortados.
USE AdventureWorks
GO
/* Create Table */
CREATE TABLE MyTable
(
ID TINYINT NOT NULL IDENTITY (1, 1),
FirstCol VARCHAR(150) NOT NULL,
TrimmedCol AS LTRIM(RTRIM(FirstCol))
) ON [PRIMARY]
GO
/* Populated Table */
INSERT INTO MyTable
([FirstCol])
SELECT ' Leading'
UNION
SELECT 'Trailing '
UNION
SELECT ' Leading and Trailing '
UNION
SELECT 'NoSpaceAround'
GO
/* SELECT Table Data */
SELECT *
FROM MyTable
GO
/* Dropping Table */
DROP TABLE MyTable
GO
Por encima de consulta demuestra que cuando recuperar datos recupera recorta datos en la columna TrimmedCol. Puede ver el resultado en la siguiente imagen.Calcula las columnas se crean ejecución tiempo y rendimiento pueden no ser óptimas si se recupera gran cantidad de datos. Algún otro tiempo veremos cómo podemos mejorar el rendimiento de columna calculada usando índice.
No hay comentarios:
Publicar un comentario