Ir al contenido principal

Función STUFF() en SQL Server

La función STUFF inserta una cadena en otra cadena. Elimina una longitud especificada de caracteres en la primera cadena en la posición inicial y luego inserta la segunda cadena en la primera cadena en la posición inicial. En otras palabras, se reemplaza una parte de la cadena con otra especificando la posición donde debe ser insertada.

A continuación, se muestra la sintaxis de la función STUFF()

STUFF (input_string , start , length , new_string )

  • input_string es la cadena que se desea modificar.
  • start es la posición inicial  en la cadena para comenzar a eliminar algunos caracteres.
  • length  es la cantidad de caracteres que se eliminarán de la cadena.
  • new_string es la nueva cadena que se insertara dentro de la cadena principal en la posicion inicial especificada start.
Como mencione, anteriormente solo reemplaza una parte de la cadena con otra en una posición especifica pero porque no usar la función REPLACE() para este caso, Facil porque esta funcion reemplaza todas las coincidencias dentro de la cadena. Mientras, que la función STUFF() no.

Veamos un ejemplo. Tenemos la siguiente frase "Este es un ejemplo" necesitamos modificarla para que diga "Este era un ejemplo".

Como podemos observar en la imagen interior al utilizar la función REPLACE() se actualizará todas las coincidencias de "es" por la palabra "era" mientras que usando la funcion STUFF() podemos especificar donde insertar la nueva cadena de texto.

La cadena principal "Este es un ejemplo" consta de 19 caracteres, y el texto que necesitamos reemplazar se encuentra en la posicion 6 despues eliminanos 2 caracteres desde la posicion 6, lo cual seria la posicion 6 y 7 [es], al finalizar se agrega la nueva cadena [era] en la posicion 6.

Si aun no has entendido,  como usar la funcion STUFF() no te preocupes, te mostrare un par de ejemplos más.

Ejemplo 1: Uso de la función STUFF() con la posición inicial 1 y elimina cero caracteres.
Ejemplo 2:  Uso de la función STUFF() para reemplazar un carácter especial de la cadena en la posicion 1 y elimina un caracter.
Ejemplo 3: Uso de la función STUFF() con el valor de la posición inicial mayor que la longitud de la cadena, como resultado nos devuelve null.
Ejemplo 4: Uso de la función STUFF() con el cero como posición inicial, el valor devuelto es null esto porque la posicion inicial debe ser mayor o igual a 1.
Ejemplo 5: Uso de la función STUFF() para eliminar y rellenar caracteres más que la longitud existente. 
Ejemplo 6: Uso de la función STUFF() con una posición inicial negativa, este caso es igual al ejemplo 4. La posicion inicial debe ser mayor o igual a 1 por lo tanto el valor devuelto es null.

Ejemplo 7: Uso de la función STUFF() con un valor de caracteres a eliminar negativo, este parametro debe ser mayor o igual a 0, por lo tanto, el valor devuelto es null.

Bueno, estos son todas las combinaciones posibles para el uso de esta función
Espero les haya gustado (n_n)/

Comentarios

Post Populares

Solucionar HybridStudioShell Cannot find one or more components. Please reinstall the application.

Hace un par de semanas instalé Magic XPA 4.8 en mi computadora y al momento de iniciar la aplicacion me muestra un mensaje de error que dice:  HybridStudioShell Cannot find one or more components. Please reinstall the application. Soluccionar este problema es muy sencillo, solo sigue estos pasos: Primero se debe desintalar Magic XPA 4.8 Después, desinstalar los siguientes programas y componentes de la computadora si es que estan instalados. Realmente, solo se debe desinstalar Microsoft Visual Studio 2015 shell (Isolated) para poder utilizar Magic XPA 4.8 pero en mi caso tenia problema con los Redistributable asi que aproveche  a instalarlo desde el instalador de Magic :3  Después instale Magic XPA 4.8 nuevamente, y con ello se reinstalara los componentes desinstalados en el paso anterior ya que Magic trae el instalador de estos componentes por si no se encuentra instalado en la PC. Al finalizar, la instalación ya podrá ingresar a Magic XPA 4.8 sin problemas. Muy Import...

Concatenar varios registros de una columna en una sola cadena SQL

 En muchas ocasiones en el trabajo me han presentado la situación de concatenar una columna o campos en una sola cadena. Es decir, como si tuviéramos que transponer la columna, pero sin complicarnos. Ejemplo: Tenemos una tabla con los nombre de los vendedores pero necesitamos que esto aparezca en una sola cadena concatenada por "punto y coma" o un delimitador especifico. El Resultado debe ser Como podemos obtener este Resultado , utilizando el siguiente Script. El script original  es el siguiente: Explicacion: @valores: Variable que guarda el nombre de los vendedores concatenados. @delimitador:  Delimitador a usar, puede ser coma o punto y coma, etc. Tabla: Tabla donde se encuentra el dato que deseamos obtener. Campo: Columna donde se encuentra la información especifica a concatenar. Bueno, esto seria todo por hoy Espero les haya gustado (n_n)/ Si desean ayudarme, puedan realizar una pequeña donación: 

Función SUBSTRING() en SQL Server

La función SUBSTRING() extrae una subcadena con una longitud especificada a partir de una ubicación en una cadena de entrada. A continuación, se muestra la sintaxis de la función SUBSTRING() : SUBSTRING(input_string, start, length); input_string puede ser un varchar, binario, texto, ntext o imagen. start es un número entero que especifica la ubicación donde comienza la subcadena que se regresara. Tenga en cuenta que el primer carácter en input_string es 1, no cero. length es un entero positivo que especifica el número de caracteres de la subcadena que se devolverá.  La función SUBSTRING() genera un error si la longitud es negativa. Si start + length > que el total del largo de input_string , la subcadena comenzará al inicio e incluirá los caracteres restantes de input_string . Ejemplo 1: Uso de la funcion SUBSTRING() , Obtener información específica Ejemplo 2: Uso de la función SUBSTRING() , Obtener información dinámica  Cómo funciona Primero, utilizamos la función C...