Бих го съхранил като date
и също така съхранява точността.
Например:
CREATE TYPE date_prec AS ENUM ('day', 'month', 'year');
CREATE TABLE pub (
pub_id integer PRIMARY KEY,
pub_date date NOT NULL,
pub_date_prec date_prec NOT NULL
);
След това можете да направите заявка към таблицата по следния начин:
SELECT pub_id, date_trunc(pub_date_prec::text, pub_date)::date FROM pub;
за да игнорирате всякакви „случайни“ стойности за ден и месец в pub_date
.