Retroceder   Foros del Web > Programación para sitios web > Bases de Datos > PostgreSQL

Respuesta
 
Herramientas Desplegado
Antiguo 11-oct-2007, 00:38   #1 (permalink)
nandogcia está en el buen camino
 
Fecha de Ingreso: enero-2003
Mensajes: 14
Ayuda Relación Reflexiva

Saludos a la comunidad. Tengo una duda en cuanto a como hacer una relación reflexiva (o recursiva) en POSTGRESQL. La relación es la siguiente:

Un elemento puede ser padre de 0,n elementos y a su vez puede ser hijo de 0,1 elementos. Según lo que he consultado en algunos libros creo que la solución es crear dos tablas asi:

Elemento (id_elemento_padre, atributos)
// clave primaria -> id_elemento_padre

Elmento_Elemento (id_elemento_hijo, atributos, id_elemento_padre)
// clave primaria -> id_elemento_hijo
// clave foránea -> id_elemento_padre

Quisiera saber si es correcta o no, puesto que si introduzco una tupla que será el elemento padre en la tabla ELEMENTO (1, maquina) , seguidamente introduzco otra tupla que será el elemento hijo en la tabla ELEMENTO (2, maquina)
¿tendré que introducir otra tupla en la tabla ELEMENTO_ELEMENTO con (2, maquina, 1)?

¿Y como se crean las tablas y la relación en POSTGRESQL, es decir, como PK, FK, PFK ...?

Gracias con antelación a quienes me puedan echar una mano.
nandogcia está desconectado   Responder Citando
Respuesta

Calificación: Calificación de Tema: 1 votos, 1,00 de promedio.


Herramientas
Desplegado

Normas de Publicación
No puedes crear nuevos temas
No puedes responder temas
No puedes subir archivos adjuntos
No puedes editar tus mensajes

BB code is Activado
Caritas están Activado
[IMG] está Activado
Código HTML está Desactivado


La Zona horaria es GMT -6. Ahora son las 22:56.


Message Board Statistics

LinkBacks Enabled by vBSEO 3.1.0

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93