Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Firebird e Interbase (https://www.clubdelphi.com/foros/forumdisplay.php?f=19)
-   -   Uso de Foreign Key en FB 2.5 (https://www.clubdelphi.com/foros/showthread.php?t=88811)

Angel.Matilla 05-08-2015 10:50:35

Uso de Foreign Key en FB 2.5
 
Haciendo unas pruebas en una base de datos definida en FB 2.5 creo que me he dado cuenta que debo tener un error de concepto. Dos de las tablas de esta base de datos están definidas así:
Código:

CREATE TABLE PERSONA (
  APELLIDOS VARCHAR(40) NOT NULL,
  NOMBRE VARCHAR(15) NOT NULL,
  REGISTRO INTEGER NOT NULL,
  CODPRV SMALLINT NOT NULL,
  NIF VARCHAR(9),
  SEXO SMALLINT,
  F_NACIM DATE,
  DOMICILIO VARCHAR(50),
  CPOSTAL VARCHAR(5),
  MUNICIPIO INTEGER,
  PROVINCIA SMALLINT,
  PROFESION INTEGER,
  C_ELECTRONICO VARCHAR(60),
  TELEFONO_1 VARCHAR(9),
  TELEFONO_2 VARCHAR(9),
  TELEFONO_3 VARCHAR(9),
  SITUACION SMALLINT,
  CORREO SMALLINT,
  LO1599 SMALLINT,
  F_ALTA DATE,
  N_AFILIADO INTEGER,
  AFILIACION SMALLINT,
  JUNTA SMALLINT,
  REFERENCIA VARCHAR(12),
  PERPAGO SMALLINT,
  FORPAGO SMALLINT,
  CUOTA DECIMAL(9, 2),
  IBAN VARCHAR(4),
  CUENTA VARCHAR(30),
  BIC VARCHAR(11),
  OBSERVACIONES BLOB SUB_TYPE 1);

ALTER TABLE PERSONA ADD CONSTRAINT PK_PERSONA PRIMARY KEY (APELLIDOS,NOMBRE,REGISTRO,CODPRV);
ALTER TABLE PERSONA ADD CONSTRAINT FK_CODAFIPER FOREIGN KEY (CODPRV,AFILIACION) REFERENCES AFILIACION(CODPRV,CODIGO) ON DELETE SET NULL;
ALTER TABLE PERSONA ADD CONSTRAINT FK_CODJUNPER FOREIGN KEY (CODPRV,JUNTA) REFERENCES JUNTA(CODPRV,CODIGO) ON DELETE SET NULL ON UPDATE CASCADE;
ALTER TABLE PERSONA ADD CONSTRAINT FK_CODMUNPER FOREIGN KEY (CODPRV,MUNICIPIO) REFERENCES POBLACION(CODPRV,CODIGO) ON DELETE SET NULL;
ALTER TABLE PERSONA ADD CONSTRAINT FK_CODPROPER FOREIGN KEY (CODPRV,PROFESION) REFERENCES PROFESION(CODPRV,CODIGO) ON DELETE SET NULL;
ALTER TABLE PERSONA ADD CONSTRAINT FK_CODPRVPER FOREIGN KEY (PROVINCIA) REFERENCES PROVINCIA(CODIGO) ON DELETE SET NULL;

CREATE INDEX AFIPER ON PERSONA(CODPRV,AFILIACION);
CREATE INDEX APENOMPER ON PERSONA(CODPRV,APELLIDOS,NOMBRE);
CREATE INDEX CTAPER ON PERSONA(CODPRV,IBAN,CUENTA);
CREATE INDEX JUNPER ON PERSONA(CODPRV,JUNTA);
CREATE INDEX MUNPER ON PERSONA(CODPRV,MUNICIPIO);
CREATE UNIQUE INDEX NUMREG ON PERSONA(CODPRV,REGISTRO);
CREATE INDEX PROPER ON PERSONA(CODPRV,PROFESION);

Código:

CREATE TABLE JUNTA (
  CODPRV SMALLINT NOT NULL,
  CODIGO SMALLINT NOT NULL,
  NOMBRE VARCHAR(30) NOT NULL,
  ZONA SMALLINT,
  PARTIDO SMALLINT);

ALTER TABLE JUNTA ADD CONSTRAINT PK_JUNTA PRIMARY KEY (CODPRV,CODIGO);
ALTER TABLE JUNTA ADD CONSTRAINT FK_CODPARJUN FOREIGN KEY (CODPRV,PARTIDO) REFERENCES PARTIDO(CODPRV,CODIGO) ON DELETE SET NULL;
ALTER TABLE JUNTA ADD CONSTRAINT FK_CODZONJUN FOREIGN KEY (CODPRV,ZONA) REFERENCES ZONA(CODPRV,CODIGO) ON DELETE SET NULL;

CREATE INDEX NOMJUN ON JUNTA(CODPRV,NOMBRE);

Yo tenía la idea que con la definición
Código:

ALTER TABLE PERSONA ADD CONSTRAINT FK_CODJUNPER
FOREIGN KEY (CODPRV,JUNTA) REFERENCES JUNTA(CODPRV,CODIGO)
ON DELETE SET NULL ON UPDATE CASCADE;

al modificar el campo código en la tabla JUNTA se actualizaba el equivalente en la tabla PERSONA. ¿Estoy equivocado?

Si no estoy equivocado teóricamente si borro un campo de la tabla JUNTA debería ponerse a NULL el equivalente en la tabla PERSONA; sin embargo si trato de eliminar un registro de la tabla JUNTA me da un error:
Cita:

The insert failed because a column definition includes validation constraints.Validation error for column "PERSONA"."CODPRV", value "*** null ***".
Y no acabo de enteder el mensaje de error que me arroja. Entiendo que es porque el campo CODPRV trata de ponerse a nulo y es parte de la clave primaria; tendría que modificarse SÓLO el campo JUNTA de la tabla PERSONA ¿Cómo puedo hacerlo?

jgutti 06-08-2015 14:39:29

para eliminar registro de la tabla JUNTA no debe existir ningun registro equivalente en tabla PERSONA(para mantener la integridad de la información).
ademas todo codigo que corresponda a junta en tabla PERSONA, obligatoriamente debe existir en tabla JUNTA.
"Si no estoy equivocado teóricamente si borro un campo de la tabla JUNTA debería ponerse a NULL el equivalente en la tabla PERSONA; sin embargo si trato de eliminar un registro de la tabla JUNTA me da un error:"

Casimiro Notevi 06-08-2015 17:29:25

Cita:

Empezado por Angel.Matilla (Mensaje 495238)
..

Creo que estás confundido en cómo funciona una base de datos relacional, si se quiere.
Has hecho varias preguntas, todas relacionadas entre sí, creo que deberías dar una leída a un tutorial SQL para aclararte las ideas.

Lepe 06-08-2015 21:05:10

Cita:

Validation error for column "PERSONA"."CODPRV", value "*** null ***".
CODPRV SMALLINT NOT NULL

El error es de validación. Se está intentando poner persona.codprv a NULL, cuando está definido en la tabla como NOT NULL.
Así que lo fácil es quitar el NOT NULL de la tabla persona.

Eso sí, te toca estudiar un poco, bueno... como a todos nosotros, que nunca dejamos de estudiar jeje.

Saludos!


La franja horaria es GMT +2. Ahora son las 17:13:54.

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi