Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > SQL
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 24-04-2007
Avatar de estebanx
estebanx estebanx is offline
Miembro
 
Registrado: dic 2004
Ubicación: Santo Domingo, Dom Rep
Posts: 52
Poder: 20
estebanx Va por buen camino
Problema con Consulta

Waoo, cuanto tiempo que no venia por estos alrededores
un saludo a todos.

Chicos!!! tengo el siguiente problema, sucede que tengo dos tablas relacionadas entre si, una llamada dtinstituciones y otra dtdirecciones
aqui va el schema de ambas

Dtinstituciones
ID, Nombre Largo, Nombre Corto

Dtdirecciones
ID, Id_institucion, id_entidad, calle

el caso es que tengo una vista, que llama la informacion de la institucion pero solo quiero tener una sola direccion
Aqui va el query
Código SQL [-]
SELECT     dbo.dtInstituciones.NombreLargo, dbo.dtInstituciones.NombreCorto, dbo.dtDirecciones.ID, dbo.dtDirecciones.ID_institucion, dbo.dtDirecciones.Calle
FROM         dbo.dtInstituciones INNER JOIN
                      dbo.dtDirecciones ON dbo.dtInstituciones.ID = dbo.dtDirecciones.ID_Institucion

el problema es que si la institucion ID 1 tiene varias direcciones me duplica los datos, quiero tener solamente una sola direccion y las otras no traerla.

Lo he hecho con top1 y distinct pero no me funciona, quiero traer todos los datos de las instituciones con una sola direccion es decir a esa vista hacer un select *

Espero que me ayuden. Gracias de antemano
Responder Con Cita
  #2  
Antiguo 24-04-2007
Avatar de Caral
[Caral] Caral is offline
Miembro Premium
 
Registrado: ago 2006
Posts: 7.659
Poder: 25
Caral Va por buen camino
Hola
Código SQL [-]
SELECT  DISTINCTROW  dbo.dtDirecciones.ID, dbo.dtInstituciones.NombreLargo, dbo.dtInstituciones.NombreCorto, dbo.dtDirecciones.ID_institucion, dbo.dtDirecciones.Calle
FROM  dbo.dtInstituciones INNER JOIN dbo.dtDirecciones ON dbo.dtInstituciones.ID = dbo.dtDirecciones.ID_Institucion
Saludos
Responder Con Cita
  #3  
Antiguo 24-04-2007
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Pero si una institución tienen dos direcciones:

Academia Vázquez, Calle del Olmo #32
Academia Vázquez, Calle de la Amargura #425

serán filas distintas y el distinctrow así las verá y se traerá ambas ¿no?

Yo había pensado, aunque siento que debe haber algo más sencillo, usar subconsultas:

Código SQL [-]
select
  dtInstituciones.*,
  (select dtDirecciones.Id where dtDirecciones.Id_institucion = dtInstituciones.Id limit 1)
  (select dtDirecciones.Id_Entidad where dtDirecciones.Id_institucion = dtInstituciones.Id limit 1),
  (select dtDirecciones.Calle where dtDirecciones.Id_institucion = dtInstituciones.Id limit 1)
from dtInstituciones

Sustituyendo el limit por el top adecuado; pero sería una subconsulta por cada columna de la tabla detalle y quizá sea muy lento.

// Saludos
Responder Con Cita
  #4  
Antiguo 24-04-2007
Avatar de Caral
[Caral] Caral is offline
Miembro Premium
 
Registrado: ago 2006
Posts: 7.659
Poder: 25
Caral Va por buen camino
Hola Roman
Me parece acertado el que el distinctrow traera las otras direcciones, pero creo si no me equivoco que al hacerlo sobre el id, distinguira este como punto de partida.
No lo he probado, pero tengo varios similares y funcionan bien, por que ni idea.
Saludos
Responder Con Cita
  #5  
Antiguo 24-04-2007
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Mmm. Puede ser. Pero al menos en MySQL, me parece que distinct y distinctrow operan sobre toda la fila y no sólo sobre una columna.

// Saludos
Responder Con Cita
  #6  
Antiguo 24-04-2007
Avatar de Caral
[Caral] Caral is offline
Miembro Premium
 
Registrado: ago 2006
Posts: 7.659
Poder: 25
Caral Va por buen camino
Hola
Ve por ejemplo esta consulta:
Código SQL [-]
SELECT DISTINCTROW BancoNac.CodTransac, BancoNac.TipoTransac, BancoNac.FechaTransac, BancoNac.Descripcion, Sum(BancoNac.Retiros) AS [Suma De Retiros], Sum(BancoNac.Depositos) AS [Suma De Depositos], Sum(BancoNac.SaldoTotal) AS SumaDeSaldoTotal
FROM BancoNac
GROUP BY BancoNac.CodTransac, BancoNac.TipoTransac, BancoNac.FechaTransac, BancoNac.Descripcion
HAVING (((BancoNac.Descripcion)<>"ANULADO"))
ORDER BY BancoNac.FechaTransac;
Me define el campo CodTransac, como inicio y no lo duplica por mas que tenga campos adicionales duplicados.
Repito, sabes que mi experiencia es muy poca, pero a mi por alguna razon me funciona, sera suerte de principiante.
Saludos
Responder Con Cita
  #7  
Antiguo 25-04-2007
Avatar de estebanx
estebanx estebanx is offline
Miembro
 
Registrado: dic 2004
Ubicación: Santo Domingo, Dom Rep
Posts: 52
Poder: 20
estebanx Va por buen camino
Cita:
Empezado por roman
Pero si una institución tienen dos direcciones:

Academia Vázquez, Calle del Olmo #32
Academia Vázquez, Calle de la Amargura #425

serán filas distintas y el distinctrow así las verá y se traerá ambas ¿no?

Yo había pensado, aunque siento que debe haber algo más sencillo, usar subconsultas:


Código SQL [-]
select
dtInstituciones.*,
(select dtDirecciones.Id where dtDirecciones.Id_institucion = dtInstituciones.Id limit 1)
(select dtDirecciones.Id_Entidad where dtDirecciones.Id_institucion = dtInstituciones.Id limit 1),
(select dtDirecciones.Calle where dtDirecciones.Id_institucion = dtInstituciones.Id limit 1)
from dtInstituciones





Sustituyendo el limit por el top adecuado; pero sería una subconsulta por cada columna de la tabla detalle y quizá sea muy lento.

// Saludos

MMM, esta interesante este codigo mas o menos asi funciona
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 con consulta ddd_ddd SQL 2 01-02-2007 17:02:53
problema con consulta sql Cosgaya SQL 4 16-01-2006 18:09:17
Problema con consulta de SQL Durbed Firebird e Interbase 2 30-09-2004 21:41:39
problema con consulta cval Firebird e Interbase 3 30-04-2004 06:33:50
problema con consulta. jsanchez SQL 2 20-05-2003 19:35:55


La franja horaria es GMT +2. Ahora son las 06:13:34.


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