En este post sobre PostgreSQL te mostraré cómo usar la función substring
para extraer parte de una cadena o cortar una cadena.
También te mostraré cómo convertir el valor a texto para que satisfaga los argumentos de la función.
Esta función toma los siguientes argumentos en orden:
Podemos usar cadenas literales o campos que ya existan. Otra forma que también funciona es:
substring(cadena from [posición] for [cuántos])
Lo veremos más a detalle con los ejemplos.
Tengo la siguiente tabla que tiene nombre y fecha de registro de usuarios. El tipo de dato del nombre es text
, pero el de la fecha es date
; más adelante verás la razón.
Si queremos extraer las primeras dos letras entonces podemos comenzar la extracción desde la posición 1, y luego tomar 2:
pruebas=# -- Mostramos todos los nombres
pruebas=# select * from nombres;
nombre | fecha_registro
--------+----------------
Luis | 2020-04-03
Maggie | 2020-04-04
Pedro | 2020-04-04
(3 filas)
pruebas=# -- Ahora extraemos las primeras 2 letras
pruebas=# select substring(nombre, 1, 2) from nombres;
substring
-----------
Lu
Ma
Pe
(3 filas)
pruebas=#
Lo mismo funcionaría usando la sintaxis de from
y for
:
pruebas=# select substring(nombre from 1 for 2) from nombres;
substring
-----------
Lu
Ma
Pe
(3 filas)
pruebas=#
Ahora mostraré otro ejemplo en donde extraemos la tercer letra. Quedaría así: select substring(nombre,3, 1) from nombres;
Con la siguiente salida:
pruebas=# select substring(nombre,3, 1) from nombres;
substring
-----------
i
g
d
(3 filas)
pruebas=#
Como lo mencioné anteriormente, también funciona con cadenas literales:
pruebas=# select substring('Parzibyte',6, 4);
substring
-----------
byte
(1 fila)
Ahora vamos a suponer que queremos extraer los primeros 4 dígitos de la fecha de registro; es decir, el año. (no tiene mucho sentido pero sirve para ejemplo).
La consulta sería algo así:
select substring(fecha_registro, 1, 4) as año, nombre from nombres;
Pero al intentar ejecutarla, la salida es:
pruebas=# select substring(fecha_registro, 1, 4) as año, nombre from nombres;
ERROR: no existe la función pg_catalog.substring(date, integer, integer)
LÍNEA 1: select substring(fecha_registro, 1, 4) as a¤o, nombre from n...
^
SUGERENCIA: Ninguna función coincide en el nombre y tipos de argumentos. Puede ser necesario agregar conversión explícita de tipos.
El error es claro y dice: no existe la función pg_catalog.substring(date, integer, integer).
Quiere decir que no existe una función definida con ese tipo de datos; ya que existe una que recibe como primer argumento un tipo text
.
Por lo tanto simplemente podemos castear como nos lo sugiere (fíjate en el ::text
):
select substring(fecha_registro::text, 1, 4) as año, nombre from nombres;
Y ahora sí funciona de maravilla:
Esto es porque la función espera un parámetro de tipo text al inicio, y nosotros le estábamos enviando uno de tipo date; lo cual se soluciona casteando o convirtiendo el tipo de dato.
Ya te enseñé cómo convertir una aplicación web de Vue 3 en una PWA. Al…
En este artículo voy a documentar la arquitectura que yo utilizo al trabajar con WebAssembly…
En un artículo anterior te enseñé a crear un PWA. Al final, cualquier aplicación que…
Al usar Comlink para trabajar con los workers usando JavaScript me han aparecido algunos errores…
En este artículo te voy a enseñar cómo usar un "top level await" esperando a…
Ayer estaba editando unos archivos que son servidos con el servidor Apache y al visitarlos…
Esta web usa cookies.