Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   C++ Builder (https://www.clubdelphi.com/foros/forumdisplay.php?f=13)
-   -   Problema con Foreign key (https://www.clubdelphi.com/foros/showthread.php?t=56788)

franfl 27-05-2008 19:21:04

Problema con Foreign key
 
Hola
Tengo ya creadas una tabla clientes y otra programa. Ahora necesito meter un campo idprograma que puede permitir null que sea foreign key de la tabla programa. Hice:

ALTER TABLE CLIENTE
add constraint IDPROGRAMA
FOREIGN KEY(IDPROGRAMA) REFERENCES PROGRAMA(IDPROGRAMA) ON DELETE CASCADE ON UPDATE CASCADE

Parece que iba todo bien hasta que en mi programa en builder le doi al boton guardar y me pone
" violation of FOREIGN KEY constraint "IDPROGRAMA" on table "CLIENTE" "

Entonces no se si es fallo de definición en el interbase o estoy haciendo algo mal en el programa.
Muchas gracias
Un saludo

maeyanes 27-05-2008 19:24:18

Hola...

El campo IDPrograma lo definiste de tal forma que pueda aceptar nulos?


Saludos...

franfl 27-05-2008 19:25:49

si
El campo IdPrograma lo defini como integer permitiendo nulos.
Gracias

BlueSteel 27-05-2008 19:43:43

Cita:

Empezado por franfl (Mensaje 289409)
Hola
Tengo ya creadas una tabla clientes y otra programa. Ahora necesito meter un campo idprograma que puede permitir null que sea foreign key de la tabla programa. Hice:


Creo que tienes un error de concepto... (aunque puede que yo este errado), si bien pudes dejar un campo nulo, ese campo no puede ser de tipo FK, ya que esta haciendo referencia a un campo clave de otra tabla... creo que esto se llama Integridad Referencial

Y debido a las reglas de integridad de datos no puede ser NULO un campo de tipo FK.


Salu2:p:D

BlueSteel 27-05-2008 19:50:49

Además, si tenemos que

Restricciones FOREIGN KEY


Una clave externa (FK) es una columna o combinación de columnas que se utiliza para establecer y exigir un vínculo entre los datos de dos tablas. Puede crear una clave externa mediante la definición de una restricción FOREIGN KEY cuando cree o modifique una tabla.

En una referencia de clave externa, se crea un vínculo entre dos tablas cuando las columnas de una de ellas hacen referencia a las columnas de la otra que contienen el valor de clave principal. Esta columna se convierte en una clave externa para la segunda tabla.


Enlace Articulo

Tambien en el mismo articulo puedo encontrar esto... y ahora me entro la duda

No es necesario que una restricción FOREIGN KEY esté vinculada únicamente a una restricción PRIMARY KEY de otra tabla; también puede definirse para que haga referencia a las columnas de una restricción UNIQUE de otra tabla. Una restricción FOREIGN KEY puede contener valores NULL, pero si alguna columna de una restricción FOREIGN KEY compuesta contiene valores NULL, se omitirá la comprobación de los valores que componen la restricción FOREIGN KEY. Para asegurarse de que todos los valores de la restricción FOREIGN KEY compuesta se comprueben, especifique NOT NULL en todas las columnas que participan.

Salu2:p:D

maeyanes 27-05-2008 19:55:31

Hola...

Si es posible tener claves (o llaves) foráneas (foreigns keys) con valores nulos (del lado del la tabla que hace la referencia)...

Algo como esto:

Código SQL [-]
create table Master (
id integer not null,
clave char(2) not null,
descripcion varchar(50) not null);

alter table Master add constraint PK_Master primary key (Id);

create table Detail (
id integer not null,
id_master integer,
clave char(2) not null,
descripcion varchar(50) not null);

alter table Detail add constraint PK_Detail primary key(id);

alter table Detail add constraint FK_Det_Ref_Master foreign key (id_master) references Master(id)
  on delete cascade on update cascade;

Saludos...

franfl 27-05-2008 19:57:08

Muchas gracias por tus molestias. Ahora tambien estoy dudando yo, pero yo creo que si puede ser nula

franfl 27-05-2008 20:01:24

Eso es lo que hice, entonces lo tengo bien, y el problema debe estar en builder, es que como cuando defines al crear una tabla una foreign key no hace falta poner lo de constrains pense que podria ser ese el error, porque no se muy bien para que sirve. Y en builder hice esto mil veces y nunca me dio este error de violation of foreign key, no se que puede ser
Gracias

franfl 27-05-2008 20:46:03

Volvi a crear la base de datos otra vez, porque tampoco era muy grande, y me sige dando el mismo error. Así que no tengo ni idea que puede ser.
Muchas gracias

franfl 29-05-2008 07:43:17

Ya lo arregle. El problema era que al permitir nulos estaba guardando un 0 en IDPROGRAMA en la tabla CLIENTE, valor que no existia en la tabla PROGRAMA. Entonces no permito nulos y por defecto les asigno un programa 0 que defini en la tabla PROGRAMA, como un registro que se llama NINGUNO.
Muchas gracias por las molestias de ayudarme
Un saludo

BlueSteel 29-05-2008 15:00:43

Cita:

Empezado por franfl (Mensaje 289804)
Ya lo arregle. El problema era que al permitir nulos estaba guardando un 0 en IDPROGRAMA en la tabla CLIENTE, valor que no existia en la tabla PROGRAMA. Entonces no permito nulos y por defecto les asigno un programa 0 que defini en la tabla PROGRAMA, como un registro que se llama NINGUNO.
Muchas gracias por las molestias de ayudarme
Un saludo


En conclusión, se puede decir que una clave foranea o FK, o FOREIGN KEY no permite valores nulos.

Si bien solucionastes tu problema, que pasará si al usuario se le dá por borrar el regisro 0 de tu tabla progama...??? ese que creastes con NINGUNO.....

Salu2:p:D

maeyanes 29-05-2008 15:16:57

Hola...

Cita:

Empezado por BlueSteel (Mensaje 289864)
En conclusión, se puede decir que una clave foranea o FK, o FOREIGN KEY no permite valores nulos.

Que si permite valores nulos... ya que yo así lo he hecho en alguna ocasión...

El problema es que el ponía en 0 el valor del campo, y 0 no es igual a NULL... en su caso lo podía resolver ya sea no asignando valor alguno al campo o asignandole NULL...

Cita:

Si bien solucionastes tu problema, que pasará si al usuario se le dá por borrar el regisro 0 de tu tabla progama...??? ese que creastes con NINGUNO.....

Salu2:p:D
Pues simplemente que no permita borrar ese registro medianto un Trigger en la base de datos o una condición dentro de la aplicación...

Saludos...

franfl 29-05-2008 19:57:05

Lo que hice fue que en la aplicación el usuario puede borar cualquier programa menos el 0, es decir, no tiene acceso a ese programa, solo lo ve en un combo cuando guarda un cliente.
Yo guardaba en idprograma el valor NULL, pero en la base datos lo tengo definido como INT, por tanto asigna el 0 automaticamente, y cuando va a la tabla PROGRAMA el 0 no existe. No se como se podria solucionar esto la verdad. Pero a mi me funciona perfectamente asi y en el programa queda mejor que aparezca NINGUNO.
Muchas gracias a todos por la atención
Un saludo


La franja horaria es GMT +2. Ahora son las 00:57:06.

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