From: | Bruce Momjian <pgman(at)candle(dot)pha(dot)pa(dot)us> |
---|---|
To: | Luke Pascoe <luke(dot)p(at)kmg(dot)co(dot)nz> |
Cc: | pgsql-sql(at)postgresql(dot)org |
Subject: | Re: checking data integrity in a recursive table |
Date: | 2003-01-31 05:32:04 |
Message-ID: | 200301310532.h0V5W4G11349@candle.pha.pa.us |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
Luke Pascoe wrote:
> Hi, I have a table that references itself to create a tree-like structure,
> eg:
> CREATE TABLE tree (
> id SERIAL NOT NULL,
> name VARCHAR(255) NOT NULL,
> parent INT NULL,
> customer IN NOT NULL,
> CONSTRAINT parent_key...
> CONSTRAINT customer_fk FOREIGN KEY (customer) REFERENCES customer
> );
> ALTER TABLE tree ADD CONSTRAINT FOREIGN KEY (parent) REFERENCES tree;
>
> As you can see tree also references the customer table.
>
> What I need is a CHECK that will ensuer that any given "tree" row has the
> same customer as its parent.
> Remember that "parent" can also be NULL.
>
> Or would this be better done as a trigger?
Good question. I don't think you can do actualy SQL lookups in a CHECK.
I think you will need a trigger, either in pl/pgsql or in C using SPI to
issue the lookup queries.
You can have a CHECK clause that deals with multiple columns:
CREATE TABLE friend2 (
firstname CHAR(15),
lastname CHAR(20),
city CHAR(15),
state CHAR(2) CHECK (length(trim(state)) = 2),
age INTEGER CHECK (age >= 0),
gender CHAR(1) CHECK (gender IN ('M','F')),
last_met DATE CHECK (last_met BETWEEN '1950-01-01'
AND CURRENT_DATE),
CHECK (upper(trim(firstname)) != 'ED' OR
upper(trim(lastname)) != 'RIVERS')
);
However, that doesn't help you because you can't reference a column in
another row of the same table.
--
Bruce Momjian | http://candle.pha.pa.us
pgman(at)candle(dot)pha(dot)pa(dot)us | (610) 359-1001
+ If your life is a hard drive, | 13 Roberts Road
+ Christ can be your backup. | Newtown Square, Pennsylvania 19073
From | Date | Subject | |
---|---|---|---|
Next Message | Dan Langille | 2003-01-31 05:33:55 | design review, FreshPorts change |
Previous Message | mallah | 2003-01-31 02:58:31 | Re: How to rename and drop a column in pg7.3? |