![]() |
![]() |
| Paypal | FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
|||||||
| Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Buscar | Temas de Hoy | Marcar Foros Como Leídos |
![]() |
|
|
Herramientas | Buscar en Tema | Desplegado |
|
|
|
#1
|
||||
|
||||
|
Ya lo probe, una pregunta como se haria en el caso de la intrucción "UNION" ???? para juntar el Máximo y el Mínimo con sus respectivos Topes.
Ahora hice pruebas como me dijo pero me marca un error, que me indica que tengo que poner la Clausula Having despues del Group By, por lo que hago esto: Select TOPE,TOPELISTA,TOPEMAY From Tabla_Marcas WHERE Marca='BIRLOS' and Grupo='TRACK' group by TOPE,TOPELISTA,TOPEMAY HAVING TOPEDOLAR=MAX(TOPEDOLAR) or TOPEDOLAR=MIN(TOPEDOLAR) funciona diferente a lo que quiero, que me visualice Solo un registro en donde aparezca el Tope Máximo con sus Topes(TOPELISTA,TOPEMAY) junto con el Tope Mínimo también con sus Topes(TOPELISTA,TOPEMAY) . De antemano Gracias por contestarme.... Última edición por AGAG4 fecha: 02-09-2004 a las 19:38:52. Razón: Correción |
|
#2
|
||||
|
||||
|
Hola.
En este caso, no estoy de acuerdo con Xavi. Con los índices adecuados esa consulta con dos subconsultas será completamente eficaz (y si no lo he entendido mal, tendria el mismo rendimiento que calcularlo mediante un procedimiento almacenado). NOTA : En este caso, el índice adecuado no es un índice sobre varios campos, sinó un índice compuesto, es decir un índice por varios campos (los campos de la agrupación más el campo por el que se maximiza). Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no). |
|
#3
|
||||
|
||||
|
Hola.
Cita:
es decir : select NOMBRE, APELLIDOS from CLIENTES union select NOMBRE, APELLIDOS from PROVEEDORES Te va a sacar todos los registros de las tablas Clientes y Proveedores. Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no). |
|
#4
|
||||
|
||||
|
Hola.
La consulta más o menos va a ser : select (select max(TOPE) from TABLA1_MARCAS where MARCA = 'CAJAS 44' and GRUPO = 'CARTON') as MAX_TOPE, (select max(TOPELISTA) from TABLA1_MARCAS where MARCA = 'CAJAS 44' and GRUPO = 'CARTON') as MAX_TOPELISTA, (select max(TOPEMAY) from TABLA1_MARCAS where MARCA = 'CAJAS 44' and GRUPO = 'CARTON') as MAX_TOPEMAY, (select min(TOPE) from TABLA1_MARCAS where MARCA = 'CAJAS 44' and GRUPO = 'CARTON') as MIN_TOPE, (select min(TOPELISTA) from TABLA1_MARCAS where MARCA = 'CAJAS 44' and GRUPO = 'CARTON') as MIN_TOPELISTA, (select min(TOPEMAY) from TABLA1_MARCAS where MARCA = 'CAJAS 44' and GRUPO = 'CARTON') as MIN_TOPEMAY from RDB$DATABASE Como ha dicho Xavi tienes 6 subconsultas, y tienes que crear 3 índices : MARCA + GRUPO + TOPE, MARCA + GRUPO + TOPELISTA, MARCA + GRUPO + TOPEMAY para que sea completamente eficaz. NOTA: Dado que solo hay que retornar una fila, he basado la consulta principal en la tabla RDB$DATABASE, que es una tabla de sistema, que sabemos que siempre existe y siempre devuelve un solo registro. (Aunque podrias haber utilizado cualquier tabla tuya, que sepas seguro que siempre contiene un único registro). Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no). |
|
#5
|
||||
|
||||
|
Por cierto, no debo haber entendido bien lo que se está buscando, puesto que ¿ que problema hay con esta simple consulta ? :
select max(TOPE) as MAX_TOPE, max(TOPELISTA) as MAX_TOPELISTA, max(TOPEMAY) as MAX_TOPEMAY, min(TOPE) as MIN_TOPE, min(TOPELISTA) as MIN_TOPELISTA, min(TOPEMAY) as MIN_TOPEMAY from TABLA1_MARCAS where MARCA = 'CAJAS 44' and GRUPO = 'CARTON'
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no). |
|
#6
|
||||
|
||||
|
Estoy de acuerdo con usted, pero solo quiero el valor Máximo y Mínimo de "TOPE", pero no quiero el Máximo de los otros dos campos "TopeLista" y "TopeMayoreo", no se si me he explicado????
Sólo quiero 1 registro en donde aparezca el Tope Máximo con sus Topes(TOPELISTA,TOPEMAY) junto con el Tope Mínimo también con sus Topes(TOPELISTA,TOPEMAY) . LOS TOPES: TOPELISTA y TOPEMAY no los quiero como Máximos De antemano Gracias por contestarme.... Última edición por AGAG4 fecha: 02-09-2004 a las 22:02:01. |
|
#7
|
||||
|
||||
|
haber si esto soluciona:
SELECT A.MAXIMO,A.TOPELISTA,A.TOPEMAY,B.MINIMO,B.TOPELISTA,B.TOPEMAY FROM (SELECT MAX(TOPE),TOPELISTA,TOPEMAY FROM TuTabla WHERE ...) AS A INNER JOIN (SELECT MIN(TOPE),,TOPELISTA,TOPEMAY FROM TuTabla WHERE ...) AS B ON A.LLAVE=B.LLAVE{aqui pones un campo llave, pero no se la estructura completa de tu tabla...} WHERE CAJAS=44 AND GRUPO=CARTON Lo que hará el INNER JOIN será juntar las dos parciales a y b en un solo registro, pero deberas encontrar la coincidencia, es decir el campo que los pueda unir, si pudieses explicar un poquito mas el fin que tendra tu consulta, asi como un poquito mas de tu estructura de BD, podré ayudarte mejor... No puedo ser mas especifico porque incluso no se bien cual es el fin de la consulta, que es lo que va a mostrar en tu aplicación pero estamos pendientes...
__________________
I.S.C. Diódoro Guillermo Avilez Alanís Consultoria y Desarrollo de Tecnologías de Información TEL +52 8180 296184.
[email protected] |
|
#8
|
||||
|
||||
|
Gracias de antemano por respondermer, pero no me funciono lo que dice...
WHERE CAJAS=44 AND GRUPO=CARTON Me marca Error en la Segundo "Select" Token unknown, la llave ya la puse va sería A.Marca=B.Marca Y como ya lo habia comentado el objetivo de esta consulta es de que me muestre el Máximo y el Mínimo valor del Campo TOPE en una sola consulta que a su vez me muestre los Campos TOPELISTA y TOPEMAY (que no van hacer por el Máximo ó Mínimo) Tengo la siguiente tabla como Ejemplo: TOPE ! TOPELISTA ! TOPEMAY ------------------------------- 11.50 ! 0.89 ! 0.74 11.66 ! 0.99 ! 0.78 11.80 ! 0.89 ! 0.78 11.84 ! 0.79 ! 0.68 Por lo que quiero que se me visualice asi en una sola consulta: TopeMax ! TopeLista ! TopeMay ! TopeMin ! TopeLista1 !TopeMay1 11.84 ! 0.79 ! 0.68 ! 11.50 ! 0.89 ! 0.74 Si redacte mal por favor digame... Gracias..... Última edición por __cadetill fecha: 03-09-2004 a las 10:04:47. |
![]() |
| Herramientas | Buscar en Tema |
| Desplegado | |
|
|
|