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 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
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 |
#2
|
||||
|
||||
Hola
Saludos |
#3
|
||||
|
||||
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:
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 |
#4
|
||||
|
||||
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 |
#5
|
||||
|
||||
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 |
#6
|
||||
|
||||
Hola
Ve por ejemplo esta consulta: 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 |
#7
|
||||
|
||||
distinctrow funciona en sqlserver 2000?
saludos |
#8
|
||||
|
||||
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 |
#9
|
||||
|
||||
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 |
#10
|
||||
|
||||
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. Bueno si esto no camina, tal vez con un group by: Como veras aqui le digo que la ultima dtDirecciones.ID, como puede ser cualquier otro campo, el que se quiera o varios. Saludos |
#11
|
||||
|
||||
Caral no me funciona last
'Last' is not a recognized function ese es el error |
#12
|
||||
|
||||
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 |
#13
|
||||
|
||||
todavia no consigo nada
|
#14
|
||||
|
||||
Cita:
MMM, esta interesante este codigo mas o menos asi funciona |
#15
|
||||
|
||||
Hola
Sigo pensando, lo has hecho alreves.? Tal vez last en primer lugar lo interprete diferente, no se pruebalo. Saludos |
#16
|
||||
|
||||
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 - |
|
|
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 |
|