On 23/03/2021 17:06, Rick Hillegas wrote:
This may help: https://stackoverflow.com/questions/29297043/on-delete-set-null-on-self-referencing-relationship

I solved this with triggers, as suggested. Problem is that the column can no longer be a foreign key.

But the other day I was playing around and found that this seems to work without any problems in other DBMSs -- even the appalling MySQL!

Any change that someone will look at implementing this in Derby for some forthcoming version?

On 3/23/21 6:09 AM, John English wrote:
I have a table in which I want to include a self-referential foreign key to the same table:

  CREATE TABLE x (
    id  INTEGER  GENERATED ALWAYS AS IDENTITY,
    idY INTEGER,
    idX INTEGER DEFAULT NULL,
    CONSTRAINT x_pk   PRIMARY KEY (id),
    CONSTRAINT x_1    FOREIGN KEY (idY)
                      REFERENCES y(id)
                      ON DELETE CASCADE,
    CONSTRAINT x_2    FOREIGN KEY (idX)
                      REFERENCES x(id)
                      ON DELETE SET NULL
  );

When I try this I get the following error:

Error: Foreign  Key 'X_2' is invalid because 'The delete rule of foreign key must be CASCADE. (The referential constraint is self-referencing and the table is dependent in a relationship with a delete rule of CASCADE.)'.
SQLState:  42915
ErrorCode: 30000

My intention is that when rows from table Y are deleted, corresponding rows from X are also deleted, but when rows from X are deleted, the references in any referencing rows in X are just set to NULL.

I don't understand exactly what I'm doing wrong here. How can I rewrite the table definition to do what I want?

Thanks,




--
John English

Reply via email to