Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Otros entornos y lenguajes > C++ Builder
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 27-05-2008
franfl franfl is offline
Miembro
 
Registrado: feb 2008
Posts: 88
Poder: 17
franfl Va por buen camino
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
Responder Con Cita
  #2  
Antiguo 27-05-2008
[maeyanes] maeyanes is offline
Capo de los Capos
 
Registrado: may 2003
Ubicación: Campeche, México
Posts: 2.732
Poder: 23
maeyanes Va por buen camino
Hola...

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


Saludos...
Responder Con Cita
  #3  
Antiguo 27-05-2008
franfl franfl is offline
Miembro
 
Registrado: feb 2008
Posts: 88
Poder: 17
franfl Va por buen camino
si
El campo IdPrograma lo defini como integer permitiendo nulos.
Gracias
Responder Con Cita
  #4  
Antiguo 27-05-2008
Avatar de BlueSteel
[BlueSteel] BlueSteel is offline
Miembro Premium
 
Registrado: may 2003
Ubicación: Concepción - Chile
Posts: 2.310
Poder: 23
BlueSteel Va por buen camino
Cool

Cita:
Empezado por franfl Ver Mensaje
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
__________________
BlueSteel

Última edición por BlueSteel fecha: 27-05-2008 a las 19:46:48.
Responder Con Cita
  #5  
Antiguo 27-05-2008
Avatar de BlueSteel
[BlueSteel] BlueSteel is offline
Miembro Premium
 
Registrado: may 2003
Ubicación: Concepción - Chile
Posts: 2.310
Poder: 23
BlueSteel Va por buen camino
Cool

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
__________________
BlueSteel

Última edición por BlueSteel fecha: 27-05-2008 a las 19:54:16.
Responder Con Cita
  #6  
Antiguo 27-05-2008
[maeyanes] maeyanes is offline
Capo de los Capos
 
Registrado: may 2003
Ubicación: Campeche, México
Posts: 2.732
Poder: 23
maeyanes Va por buen camino
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...

Última edición por maeyanes fecha: 29-05-2008 a las 15:18:18.
Responder Con Cita
  #7  
Antiguo 27-05-2008
franfl franfl is offline
Miembro
 
Registrado: feb 2008
Posts: 88
Poder: 17
franfl Va por buen camino
Muchas gracias por tus molestias. Ahora tambien estoy dudando yo, pero yo creo que si puede ser nula
Responder Con Cita
  #8  
Antiguo 27-05-2008
franfl franfl is offline
Miembro
 
Registrado: feb 2008
Posts: 88
Poder: 17
franfl Va por buen camino
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
Responder Con Cita
  #9  
Antiguo 27-05-2008
franfl franfl is offline
Miembro
 
Registrado: feb 2008
Posts: 88
Poder: 17
franfl Va por buen camino
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
Responder Con Cita
  #10  
Antiguo 29-05-2008
franfl franfl is offline
Miembro
 
Registrado: feb 2008
Posts: 88
Poder: 17
franfl Va por buen camino
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
Responder Con Cita
  #11  
Antiguo 29-05-2008
Avatar de BlueSteel
[BlueSteel] BlueSteel is offline
Miembro Premium
 
Registrado: may 2003
Ubicación: Concepción - Chile
Posts: 2.310
Poder: 23
BlueSteel Va por buen camino
Cool

Cita:
Empezado por franfl Ver Mensaje
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
__________________
BlueSteel
Responder Con Cita
  #12  
Antiguo 29-05-2008
[maeyanes] maeyanes is offline
Capo de los Capos
 
Registrado: may 2003
Ubicación: Campeche, México
Posts: 2.732
Poder: 23
maeyanes Va por buen camino
Hola...

Cita:
Empezado por BlueSteel Ver Mensaje
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
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...
Responder Con Cita
  #13  
Antiguo 29-05-2008
franfl franfl is offline
Miembro
 
Registrado: feb 2008
Posts: 88
Poder: 17
franfl Va por buen camino
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
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
problema foreign key sargento elias Conexión con bases de datos 4 21-04-2008 22:51:05
violation of Foreign Key JulioGO Firebird e Interbase 2 27-06-2006 00:33:24
foreign key clanmilano Conexión con bases de datos 4 03-11-2005 03:21:19
Foreign key fjardelphi Firebird e Interbase 2 20-12-2004 16:05:39
uso de FOREIGN KEY jzginez Firebird e Interbase 2 22-04-2004 23:20:25


La franja horaria es GMT +2. Ahora son las 12:36:56.


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
Copyright 1996-2007 Club Delphi