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 Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
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
  #2  
Antiguo 29-05-2008
[maeyanes] maeyanes is offline
Capo de los Capos
 
Registrado: may 2003
Ubicación: Campeche, México
Posts: 2.732
Poder: 24
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
  #3  
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



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 07:42:11.


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