![]() |
![]() |
| Paypal | FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
|||||||
| Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
![]() |
|
|
Herramientas | Buscar en Tema | Desplegado |
|
|
|
#1
|
||||
|
||||
|
Ok, estoy armando un sistema de reporteador tipo OLAP.
Quiero que el sistema automagicamente deduzca las relaciones entre las tablas que el usuario selecciona. Tengo estas tablas relacionadas asi: Municipio 1-* Barra Cliente 1-* Barra Banco 1-* EncabezadoMovimiento Cliente 1-* EncabezadoMovimiento Asi que quiero preguntar:
Tengo todo dentro de un grafo, y ya le aplico un algoritmo de ruta corta para sacar la forma mas eficiente de relacionar, pero no se como substraer de un grafo un subgrafo que sea conectado. Alguna idea? Seudocodigo estario Ok o ejemplo en cualquier lenguaje menos assembler.
__________________
El malabarista. |
|
#2
|
||||
|
||||
|
Le he dado vueltas en google y no encuentro un ejemplo de como poder hacer esto, y me parece que deberia ser un caso comun...
Creo que voy a tener que gastarle mas neuronas de lo anticipado...
__________________
El malabarista. |
|
#3
|
||||
|
||||
|
Hola Mamx,
Tengo un tanto oxidada la cátedra de estructura de datos, sobre todo la parte de grafos. No se que tanto te podría ser de ayuda. Pero al menos puedo prestar parte de mi cabeza, Cabeza y media piensan más que una. No termino de comprender como es que empleas grafos para representar las relaciones. Si me pudieras dar una pequeña descripción de ello tal vez comprenda mejor algunas cosas. ¿Estás empleando alguna fuente bibliográfica en particular? Creo que tengo mi carpeta de Estructuras de dato a mano... puede que encuentre algo que sirva. Pero primero me gustaría sacarme esa duda: ¿Como es que haces la representación de las relaciones con grafos? ![]() No he dicho algo de utilidad, pero si en algo puedo serte útil pegame el grito. Saludos, |
|
#4
|
||||
|
||||
|
De forma muy simple, como con los programas que diagraman las tablas tipo UML.
Cada nodo es un tabla, luego usando vertices conecto la tabla de origen con la de destino. Solo conecto tablas, no campos porque en mi estructura es innecesario. Asi que sale mas o menos: Cita:
__________________
El malabarista. |
|
#5
|
||||
|
||||
|
Hola mamx,
Dejame ver si te entiendo... Entonces tienes un grafo más o menos como este: Código:
+---+ +---+ +---+ +---+ +---+ | M |----| B |----| C |----| E |----| B | +---+ +---+ +---+ +---+ +---+ Se lo vemos como un DER la cosa queda así: Código:
+---+ +---+ +---+ +---+ +---+ | M |-|---<| B |>---|-| C |-|---<| E |>---|-| B | +---+ +---+ +---+ +---+ +---+ ¿Estás empleando Dijkstra? El algoritmo de Dijkstra, si no falla la cabeza, lo que hace es calcular la distancia mínima desde un Nodo a TODOS los demás. Y si obtenemos las distancias mínimas de un nodo a otro se puede recorrer la estructura a través de dichos mínimos y deternos cuando se haya llegado al nodo destino. A lo que voy es que el algoritmo de Dijkstra va etiquetando los nodos y llevando una estructura desde los mínimos hasta los máximos, en forma acumulada. Como dicha estructura contiene a todos los nodos, en vez de llegar hasta el final, parar el algoritmo ni bien de detecte el nodo que queremos como destino. ¿O yo estoy comprendiendo mal el problema? ![]() No se... ya me estoy confundiendo. Lo que estás buscando es que dada dos tablas (nodos) el sistema devuelva las relaciones entre dichas tablas (nodos), entonces si partimos de un nodo a otro ira estableciendo las relaciones hasta llegar al nodo destino. Hay algo que se me escapa ![]() Saludos, |
|
#6
|
||||
|
||||
|
Efectivamente uso Dijkstra. No tengo problema en saber la ruta minima.
MI problema es como extraigo un subconjunto del grafo total que representa todas las relaciones de las tablas en la BD a uno mas pequeño que solo contenga las que se seleccionaron y las que hacen falta para conectar esas tablas entre si. Si tengo una tabla cliente, encabezado y detalle de factura, y selecciono a detalle y cliente, quiero que devuelva a las 3, porque encabezado es indispensable para relacionar a cliente y detalle.
__________________
El malabarista. |
![]() |
|
|
Temas Similares
|
||||
| Tema | Autor | Foro | Respuestas | Último mensaje |
| Ver relaciones de las tablas | ManuelPerez | Varios | 4 | 17-03-2008 18:32:12 |
| Como Manejo Las Relaciones Entre Dos Tablas En Ibadmin 3 De Interbase | afal3d | Firebird e Interbase | 2 | 13-06-2007 19:54:13 |
| Relaciones en tablas .dbf | snowlis | Conexión con bases de datos | 6 | 15-04-2007 11:00:41 |
| Tablas y Relaciones 2 | leodelca23 | Tablas planas | 4 | 13-09-2006 23:40:06 |
| Como extraer datos de 3 tablas SQL | MRang14 | SQL | 0 | 04-10-2004 21:29:21 |
|