Company logo
  • Empleos
  • Bootcamp
  • Acerca de nosotros
  • Para profesionales
    • Inicio
    • Empleos
    • Cursos y retos
    • Preguntas
    • Profesores
    • Bootcamp
  • Para empresas
    • Inicio
    • Nuestro proceso
    • Planes
    • Pruebas
    • Nómina
    • Blog
    • Comercial
    • Calculadora

0

109
Vistas
Postgresql return variable in type stored in a table

I'm currently developing an app and encountered a problem when trying to create a query on a table that uses a custom type.

Here is an example table and type,

CREATE TYPE address AS (
  street varchar(40),
  city   varchar(25),
  zip    varchar(5)
);
CREATE TABLE houses (
  id SERIAL PRIMARY KEY,
  address address
);

I need to retrieve a list with all the cities stored in the table houses. Here's what I tried to do:

SELECT address.city
FROM houses
GROUP BY address.city

It detects address.city as a table. Is there any way to do what I want to do in PostgreSQL?

9 months ago · Santiago Trujillo
1 Respuestas
Responde la pregunta

0

I would not use a compound type like that in a table. But you can still do this, use parenthesis.

SELECT (address).city
FROM houses
GROUP BY (address).city

From the docs

To access a field of a composite column, one writes a dot and the field name, much like selecting a field from a table name. In fact, it's so much like selecting from a table name that you often have to use parentheses to keep from confusing the parser.

Instead, I would use a jsonb. Or, if you're going to use a compound type you should use stdaddr from PostGIS.

9 months ago · Santiago Trujillo Denunciar
Responde la pregunta
Encuentra empleos remotos