Re: DEFAULT Constraint based on table type?

Поиск
Список
Период
Сортировка
От Jaime Casanova
Тема Re: DEFAULT Constraint based on table type?
Дата
Msg-id c2d9e70e0511281414m5b8ed807t11ad7d85ffeeba4@mail.gmail.com
обсуждение исходный текст
Ответ на DEFAULT Constraint based on table type?  ("Announce" <truthhurts@insightbb.com>)
Список pgsql-sql
On 11/28/05, Announce <truthhurts@insightbb.com> wrote:
> Lets say I have the following tables.
>
> CREATE TABLE animals(id primary key, name varchar, type varchar);
> CREATE TABLE dogs (breed varchar)            INHERITS (animals);
> CREATE TABLE birds (bool hasFeathers) INHERITS (animals);
>
> Is there a way I can specify a default on the child table that will populate
> the 'type' column? For example, if I am inserting a row in table DOGS, I
> would always want the default value for column TYPE to be 'DOG'. If I am
> inserting into BIRDS.... type 'BIRD'.
>
> I know that I could add individual triggers on each table that set the TYPE
> field to a default value on insert but I wanted a more simple solution like
> setting a DEFAULT table-constraint.
>
> Also, In java, this could be done on a parent object by overriding a
> constructor or method, using the Class object or instanceof.  Is there
> anyway for a table to "know" it's "class" in this scenario?
>
> Thanks,
>
> -Aaron
>

CREATE TABLE animals(id primary key, name varchar, type varchar);

CREATE TABLE dogs (breed varchar)            INHERITS (animals);
ALTER TABLE dogs ALTER COLUMN type SET DEFAULT 'DOG';

CREATE TABLE birds (bool hasFeathers) INHERITS (animals);
ALTER TABLE birds ALTER COLUMN type SET DEFAULT 'BIRD';


--
regards,
Jaime Casanova
(DBA: DataBase Aniquilator ;)


В списке pgsql-sql по дате отправления:

Предыдущее
От: "Announce"
Дата:
Сообщение: DEFAULT Constraint based on table type?
Следующее
От: Rod Taylor
Дата:
Сообщение: Re: DEFAULT Constraint based on table type?