FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
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 |
#2
|
|||
|
|||
Hola...
El campo IDPrograma lo definiste de tal forma que pueda aceptar nulos? Saludos... |
#3
|
|||
|
|||
si
El campo IdPrograma lo defini como integer permitiendo nulos. Gracias |
#4
|
||||
|
||||
Cita:
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. |
#5
|
||||
|
||||
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. |
#6
|
|||
|
|||
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:
Saludos... Última edición por maeyanes fecha: 29-05-2008 a las 15:18:18. |
#7
|
|||
|
|||
Muchas gracias por tus molestias. Ahora tambien estoy dudando yo, pero yo creo que si puede ser nula
|
#8
|
|||
|
|||
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 |
#9
|
|||
|
|||
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 |
#10
|
|||
|
|||
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 |
#11
|
||||
|
||||
Cita:
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 |
#12
|
|||
|
|||
Hola...
Cita:
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:
Saludos... |
#13
|
|||
|
|||
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 |
|
|
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 |
|