Las traducciones son generadas a través de traducción automática. En caso de conflicto entre la traducción y la version original de inglés, prevalecerá la version en inglés.
Función de TRANSLATE
Para una expresión dada, reemplaza todas las coincidencias de caracteres especificados con sustitutos especificados. Los caracteres existentes se asignan a caracteres de reemplazo en función de su posición en los argumentos characters_to_replace y characters_to_substitute. Si se especifican más caracteres en el argumento characters_to_replace que en el argumento characters_to_substitute, los caracteres adicionales del argumento characters_to_replace se omiten en el valor devuelto.
TRANSLATEes similar a Función de REPLACE y theREGEXP_ función REPLACE, con la salvedad de que REPLACE sustituye una cadena completa por otra y REGEXP _ REPLACE permite buscar en una cadena un patrón de expresión regular, a la vez TRANSLATE que sustituye múltiples caracteres de un solo carácter.
Si un argumento es nulo, el valor de retorno es NULL.
Sintaxis
TRANSLATE ( expression, characters_to_replace, characters_to_substitute )
Argumentos
- expresión
-
La expresión que se traducirá.
- characters_to_replace
-
Una cadena que tiene los caracteres que se reemplazarán.
- characters_to_substitute
-
Una cadena que tiene los caracteres que se sustituirán.
Tipo de retorno
VARCHAR
Ejemplos
En el siguiente ejemplo, se reemplazan varios caracteres en una cadena:
select translate('mint tea', 'inea', 'osin'); translate ----------- most tin
En el siguiente ejemplo, se reemplaza el signo (@) con un punto para todos los valores en una columna:
select email, translate(email, '@', '.') as obfuscated_email from users limit 10; email obfuscated_email ------------------------------------------------------------------------------------------- Etiam.laoreet.libero@sodalesMaurisblandit.edu Etiam.laoreet.libero.sodalesMaurisblandit.edu amet.faucibus.ut@condimentumegetvolutpat.ca amet.faucibus.ut.condimentumegetvolutpat.ca turpis@accumsanlaoreet.org turpis.accumsanlaoreet.org ullamcorper.nisl@Cras.edu ullamcorper.nisl.Cras.edu arcu.Curabitur@senectusetnetus.com arcu.Curabitur.senectusetnetus.com ac@velit.ca ac.velit.ca Aliquam.vulputate.ullamcorper@amalesuada.org Aliquam.vulputate.ullamcorper.amalesuada.org vel.est@velitegestas.edu vel.est.velitegestas.edu dolor.nonummy@ipsumdolorsit.ca dolor.nonummy.ipsumdolorsit.ca et@Nunclaoreet.ca et.Nunclaoreet.ca
En el siguiente ejemplo, se reemplazan espacios con guiones bajos y se quitan los puntos para todos los valores en una columna:
select city, translate(city, ' .', '_') from users where city like 'Sain%' or city like 'St%' group by city order by city; city translate --------------+------------------ Saint Albans Saint_Albans Saint Cloud Saint_Cloud Saint Joseph Saint_Joseph Saint Louis Saint_Louis Saint Paul Saint_Paul St. George St_George St. Marys St_Marys St. Petersburg St_Petersburg Stafford Stafford Stamford Stamford Stanton Stanton Starkville Starkville Statesboro Statesboro Staunton Staunton Steubenville Steubenville Stevens Point Stevens_Point Stillwater Stillwater Stockton Stockton Sturgis Sturgis