Quitar una cadena de texto de muchos registros usando SQL

En una aplicación en la que estoy trabajando, surgió la necesidad de actualizar muchos registros de la base de datos, específicamente, lo que necesitaba era quitar un texto común dentro de un mismo campo para muchos registros.

Para ser más explícito, tenía algo como esto dentro de una tabla en la base de datos:

id filepath
1 files/archivo1
2 files/archivo2
3 files/archivo3
4 archivo4

Y necesitaba quitar el texto files/ de los registros que lo tuvieran. La magia nos la dará entonces la función REPLACE dentro de una sentencia UPDATE de SQL:

UPDATE {tabla}
SET {campo} = REPLACE({campo}, '{texto original}', '{texto de reemplazo}')
WHERE {campo} LIKE '{texto original}%'

En mi caso, la sentencia sería como sigue:

UPDATE files
SET filepath = REPLACE(filepath, 'files/', '')
WHERE filepath LIKE 'files/%'

Esto hace que primero se filtren los registros cuyo campo filepath comienza por la cadena files/ (nótese el signo de porcentaje solo al final), y luego se reemplace dicho campo por el resultado de la función REPLACE. Esta función toma el valor del campo, busca ahí la cadena files/ y la reemplaza por una cadena vacía (consiguiendo el efecto deseado).

La sentencia WHERE no es completamente necesaria, solo me aseguro que afecte a los registros donde el campo filepath comienza con ese texto y no a los que tengan el texto en otra posición.

Leave a Reply

Your email address will not be published. Required fields are marked *

Are you human? *