Estoy ejecutando Postgres 12. Tengo un tipo compuesto de campo de auditoría que hice para evitar que mis tablas sean demasiado gruesas.
create type adt_flds as ( created_at timestamp, updated_at timestamp, created_by text, updated_by text, created_by_client_addr inet, updated_by_client_addr inet, created_by_client_cmptr text, updated_by_client_cmptr text ); create table if not exists excel.equip_type ( equip_type_id serial not null constraint equip_type_pk primary key, descrip text, adt_flds adt_flds ); --Creates a syntax error create index equip_type_adt_flds_index on excel.equip_type (adt_flds.created_at);
Llegué al punto en el que me gustaría indexar el campo created_at, de modo que cuando filtro en created_at en mis declaraciones WHERE, mis consultas pueden indexar el escaneo y no el escaneo del montón. Mi problema es que termino con un error de sintaxis en mi declaración de creación de índice. ¿Cómo arreglaría mi sintaxis para poder tener un índice en solo 1 elemento de mi tipo adt_flds
?
[42601] ERROR: error de sintaxis en o cerca de ")" Posición: 85
La documentación de PostgreSQL es bastante clara sobre la sintaxis de los índices que se crean en una expresión en lugar de una columna de tabla:
La expresión generalmente debe escribirse entre paréntesis, como se muestra en la sintaxis. Sin embargo, los paréntesis se pueden omitir si la expresión tiene la forma de una llamada de función.
Necesita paréntesis adicionales para la desambiguación.
Tratar
CREATE INDEX equip_type_adt_flds_index ON excel.equip_type (((adt_flds).created_at));