FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
||||
|
||||
Sobre el uso de MAX
Hola a todos!!!
A ver si pueden echarme una mano con una consulta que no sale, ¿será la hora? (Son las 23:03) Simplificaré un poco las tablas para que se entienda: EMPRESA ------- EMPRESA_CODIGO PK EMPRESA_NOMBRE TIPO ---- TIPO_CODIGO PK TIPO_NOMBRE PRODUCTO -------- PRODUCTO_CODIGO PK EMPRESA_CODIGO FK TIPO_CODIGO FK PRODUCTO_FECHA PRODUCTO_PRECIO Lo que quiero obtener es un listado por empresas donde me aparezca: EMPRESA - TIPO - PRODUCTO - FECHA - PRECIO Pero que solo me muestre la fecha mayor. Tengo la consulta así:
y ahora mismo no veo como hacer para que de cada unión EMPRESA-TIPO me seleccione la fecha mayor. Gracias de antemano por la ayuda...
__________________
Saludos, Gabo A menos que se indique lo contrario, el código estará hecho en C++Builder. |
#2
|
||||
|
||||
No me aclaro bien con tu consulta ....
Deseas obtener un listado de la tabla Productos, o un listado de la tabla Empresas ? Lo digo porque en tu condición 'From' especificas que obtenga los registros de la tabla Productos. Si pudieras indicar un set de datos de terminados como ejemplo, y el resultado que deseas obtener, intentaría ayudarte.
__________________
Piensa siempre en positivo ! |
#3
|
||||
|
||||
Cita:
Con éste me quedo en +1 (no en post, si no en deuda contigo ) Quiero obtener un listado de la tabla Productos. Supongamos que: Código:
EMPRESA ------- 01 JB MARTINEZ 02 COLABE, SA TIPO ---- 11 SEGUNDA 12 PRIMERA PRODUCTO -------- 21 01 11 02/12/07 23,34 22 01 12 01/12/07 20,67 23 02 11 04/12/07 56,67 24 01 11 03/12/07 26,78 25 02 11 07/12/07 34,56 26 01 12 08/12/07 56,78 Código:
TIPO EMPRESA PRODUCTO FECHA PRECIO --------------------------------------------------- PRIMERA JB MARTINEZ 26 08/12/07 56,78 SEGUNDA COLABE,SA 25 07/12/07 34,56 SEGUNDA JB MARTINEZ 24 03/12/07 26,78
__________________
Saludos, Gabo A menos que se indique lo contrario, el código estará hecho en C++Builder. Última edición por Gabo fecha: 01-03-2008 a las 00:02:22. |
#4
|
||||
|
||||
A ver si esto funcionara ....
Insisto .... no lo he probado. Pero me remito adicionalmente a este hilo Saludos
__________________
Piensa siempre en positivo ! |
#5
|
||||
|
||||
Ya me he dado cuenta de un fallo del código que acabo de poner.
Supongo que deseas obtener el precio correspondiente a la mayor fecha, no el mayor precio .... no es verdad ? Con la sentencia que te he puesto, no se obtiene así. Se obtiene por un lado la mayor fecha, y por otro lado el mayor de los precios para cada uno de los registros del Group By ... A ver .... estoy en ello.
__________________
Piensa siempre en positivo ! |
#6
|
||||
|
||||
Cita:
Además, con los group by de esa forma da el error de "referencia de columna inválida" y al ajustarlo a los campos del select no filtra por el mayor, sino que los muestra todos. He visto también la solución del otro hilo, voy a intentar adaptarla...
__________________
Saludos, Gabo A menos que se indique lo contrario, el código estará hecho en C++Builder. |
#7
|
||||
|
||||
Sobre la otra solución:
La adapté y quedo así:
Pero el problema es que al hacer "SELECT MAX(PRODUCTO.PRODUCTO_FECHA)" le estoy diciendo arbitrariamente que coloque en todos los registros que obtenga la fecha mayor y no que muestre sólo la mayor
__________________
Saludos, Gabo A menos que se indique lo contrario, el código estará hecho en C++Builder. |
#8
|
||||
|
||||
Por más que lo pienso, creo que no es posible con un simple 'Select'.
El error que indicas arriba de 'referencia de columna inválida' no es mayor problema. Bastaría incluir todos aquellos campos que no sean 'Max' en el Group By, aunque sean los respectivos nombres de empresas y tipos obtenidos de los join. Analizando el asunto .... necesitas obtener el 'Producto_Codigo' para cada uno de los valores del Max(Fecha). Una vez que tuvieras ese 'Producto_Codigo' podrías obtener el precio correspondiente a ese registro. Y ahí veo el problema. No sé cómo obtenerlo. Lo único que se me ocurre es incluir dos DataSet's en tu aplicación, uno para calcular el Max(Fecha) por cada Producto, y el segundo DataSet que sea 'detalle' del primer DataSet 'maestro', y esten referenciados por esa columna 'Maxima Fecha' obtenida. Y ya en el segundo DataSet buscas el 'Producto_Codigo' y su correspondiente 'Precio' asociado. Si no lo haces con dos DataSet's, entonces veo la necesitad de implementar un Stored Procedure que te lo resuelva. Con ello si que no sería mayor problema. Si a alguien se le ocurre otra solución, bienvenida sea !
__________________
Piensa siempre en positivo ! |
#9
|
||||
|
||||
Pues yo tampoco veo muy claro el asunto. Entre las dos opciones que me das, creo que me quedo con el procedimiento almacenado.
De todas formas, lo veré mañana que ya es la 1:00 y me levanto a las 5:30 ¡Gracias por la ayuda gluglu!
__________________
Saludos, Gabo A menos que se indique lo contrario, el código estará hecho en C++Builder. |
#10
|
||||
|
||||
Hola Gabo
Nose si te he entendido, pero talvez podrías hacer una subconsulta para obtener las fechas maximas agrupado por tipo y empresa.
Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar. Última edición por Caro fecha: 01-03-2008 a las 16:19:38. |
#11
|
||||
|
||||
Bravo, Caro !
A primera vista me parecía que no funcionaría, pero haciendo ciertas pruebas con sets de datos propios, creo que sí, que funciona. A ver si Gabo puede probar esa sentencia con sus propios datos y confirmar que el Select devuelve los datos como él desea.
__________________
Piensa siempre en positivo ! |
#12
|
||||
|
||||
Pues va a ser que no ....
Tal y como estoy dándole a enviar al post anterior, me doy cuenta que no funciona correctamente. Al probarlo con mi propio set de datos, resulta que la condición del Max la estaba poniendo a un campo cuyos valores son únicos. Es decir, dos registros diferentes no pueden tener el mismo valor de ese campo. Aplicado al ejemplo de Gabo. Si la fecha fuera única para cada registro, entonces funcionaría. En el ejemplo que ha puesto Gabo, las fechas si son únicas. Pero Gabo tendría que confirmar si en una misma fecha puede haber dos Empresas diferentes con precios diferentes. Si fuera así, debo de entender que no funcionaría. Pero aun así, me queda la duda. En cualquier caso, deberíamos de saber si la fecha es única.
__________________
Piensa siempre en positivo ! |
#13
|
||||
|
||||
Efectivamente, lo he probado y creo ratificarme en mi comentario anterior.
Con el set de datos de Gabo funciona perfectamente, y la lógica es correcta. En cambio, si las fechas se pueden repetir, no funciona. Por ejemplo he probado con los siguientes registros en la Tabla Productos: Código:
PRODUCTO -------- 21 01 11 02/12/07 23,34 22 01 12 01/12/07 20,67 23 02 11 04/12/07 56,67 24 01 11 03/12/07 26,78 25 02 11 07/12/07 34,56 26 01 12 08/12/07 56,78 27 02 11 08/12/07 99,99 28 02 12 08/12/07 88,88 29 02 12 08/12/07 77,77 Código:
TIPO EMPRESA PRODUCTO FECHA PRECIO --------------------------------------------------- PRIMERA JB MARTINEZ 26 08/12/07 56,78 PRIMERA COLABE 28 08/12/07 88,88 PRIMERA COLABE 29 09/12/07 77,77 SEGUNDA JB MARTINEZ 24 03/12/07 26,78 SEGUNDA COLABE 27 08/12/07 99,99
__________________
Piensa siempre en positivo ! |
#14
|
||||
|
||||
Hola,
antes que todo, perdón por la demora, pero el fin de semana no he estado en casa y el lunes he tenido que andar corriendo de una empresa a otra... Gracias Caro por tu respuesta. En principio pensé que funcionaba bien, pero tal como ha dicho gluglu presenta un fallo cuando dos empresas tienen una oferta un mismo día. Puede darse el caso de que te aparezcan dos ofertas (de distinta fecha) de una empresa a un tipo de producto por encontrarse dicha fecha en el listado del primer select. Hoy estaré liado también , pero mañana intentaré darle solución con un procedimiento y lo publico... Un saludo a todos y gracias por el interés, en especial a gluglu y a Caro...
__________________
Saludos, Gabo A menos que se indique lo contrario, el código estará hecho en C++Builder. |
#15
|
||||
|
||||
Les cuento como quedó todo a las finales...
Como me apuraba un poco la solución y todavía no me manejo bien con los procedimientos (los saco pero me demoro ) a las finales lo resolví así: Primero ejecuto esta consulta:
Con lo que obtengo los tres datos que identifican a los registros de la tabla producto que me interesan, ya que la fecha nunca se repite para un mismo tipo y empresa. Luego con esos tres datos, obtengo el nombre del producto y su precio, el nombre del tipo y el nombre de la empresa. No dudo que habrán modos mejores y más rápidos de implementar, pero este fue el más rápido que se me ocurrió. Gracias a todos nuevamente...
__________________
Saludos, Gabo A menos que se indique lo contrario, el código estará hecho en C++Builder. |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Articulo sobre la facilidad de probar componentes open source en windows sobre linux | gmontes | Noticias | 0 | 22-08-2007 22:34:16 |
|