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 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
distinctrow funciona en sqlserver 2000?

saludos
Responder Con Cita
  #8  
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
Dicen que para muestra un boton, pruebalo.
Sqlserver, es familia de access, si funciona en esta debe funcionar CREO en Sqlserver, probando, uno, dos, tres.
En teoria las sentencias sql, varian en muy poca cosa de un motor a otro.
Saludos
Responder Con Cita
  #9  
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
GRACIAS caral por tu ayuda en sql server distinctrow cambia a distinct

http://www.microsoft.com/technet/pro....mspx?mfr=true

y no, no me funciona
Responder Con Cita
  #10  
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 estebanx
Complicado no es:
Es cuestion de enfocar el problema a lo que se necesita.
Quieres que te salga solo una direccion X de una dtDirecciones.ID X, Bueno hay que pensar en cual de todas, la ultima, la primera, cual, alguna tiene que ser, verdad, la maquina no entiende cual quieres, entonces hay que decirselo.
Código SQL [-]
SELECT  DISTINCT  Last(dbo.dtDirecciones.ID) AS 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
Bueno si esto no camina, tal vez con un group by:
Código SQL [-]
SELECT  DISTINCT  Last(dbo.dtDirecciones.ID) AS 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
GROUP BY dbo.dtInstituciones.NombreLargo, dbo.dtInstituciones.NombreCorto, dbo.dtDirecciones.ID_institucion, dbo.dtDirecciones.Calle
Como veras aqui le digo que la ultima dtDirecciones.ID, como puede ser cualquier otro campo, el que se quiera o varios.
Saludos
Responder Con Cita
  #11  
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
Caral no me funciona last
'Last' is not a recognized function

ese es el error
Responder Con Cita
  #12  
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
Que raro es sqlserver, ya se por que no lo uso
Se tendria que buscar una palabra que aplique esta funcion last(ultimo), no se funciona, first.
Tienes que ir por esa ruta, buscar la manera en que la consulta entienda lo que necesitas, logicamente con las palabras adecuadas, en la guia de sqlserver.
Ha seguir intentando.
Roman, alguna idea?
Saludos
Responder Con Cita
  #13  
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
todavia no consigo nada
Responder Con Cita
  #14  
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
  #15  
Antiguo 25-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
Sigo pensando, lo has hecho alreves.?
Código SQL [-]
SELECT  DISTINCT  dbo.dtInstituciones.NombreLargo, dbo.dtInstituciones.NombreCorto, dbo.dtDirecciones.ID_institucion, dbo.dtDirecciones.Calle, Last(dbo.dtDirecciones.ID) AS dtDirecciones.ID
FROM  dbo.dtInstituciones INNER JOIN dbo.dtDirecciones ON dbo.dtInstituciones.ID = dbo.dtDirecciones.ID_Institucion
Tal vez last en primer lugar lo interprete diferente, no se pruebalo.
Saludos
Responder Con Cita
  #16  
Antiguo 26-04-2007
Avatar de fjcg02
[fjcg02] fjcg02 is offline
Miembro Premium
 
Registrado: dic 2003
Ubicación: Zamudio
Posts: 1.410
Poder: 22
fjcg02 Va camino a la fama
Código SQL [-]
SELECT dbo.dtInstituciones.NombreLargo,  -- en el group by 
           dbo.dtInstituciones.NombreCorto,  -- en el group by
           first(dbo.dtDirecciones.ID), 
           first(dbo.dtDirecciones.ID_institucion), 
           first(dbo.dtDirecciones.Calle)
FROM  dbo.dtInstituciones INNER JOIN
         dbo.dtDirecciones ON dbo.dtInstituciones.ID =
         dbo.dtDirecciones.ID_Institucion
GROUP BY dbo.dtInstituciones.NombreLargo, dbo.dtInstituciones.NombreCorto
Cuando quieres hacer algo similar, siempre tendrás que utilizar funciones de agrupación. En este caso, y como comentabais anteriormente, si una institución tiene 2 direcciones siempre saldrá dos veces. Para evitarlo, utiliza GROUP BY. Agrupas por los campos que quieres que sólo salgan una vez, el resto , función de grupo. En este caso yo he utilizado first, que muestra la primera que encuentra, podrías usar last, y si el campo es numérico first - primero, last - ultimo, sum- suma, average - media, min -minimo o max - maximo...

Ten en cuenta que cuando uses Group by cualquier campo que no tenga una función de las antes indicadas, seberá aparecer detrás del group by.

Espero haberte ayudado.

Un saludo
__________________
Cuando los grillos cantan, es que es de noche - viejo proverbio chino -
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 02:06:36.


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