PDA

Ver la Versión Completa : Uso de Foreign Key en FB 2.5


Angel.Matilla
05-08-2015, 10:50:35
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í:
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);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
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:
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
..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
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!