Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > SQL
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 02-09-2004
Avatar de AGAG4
AGAG4 AGAG4 is offline
Miembro
 
Registrado: ago 2004
Ubicación: Los Mochis, Sinaloa, México
Posts: 1.420
Poder: 23
AGAG4 Va por buen camino
Post oki

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
Responder Con Cita
  #2  
Antiguo 02-09-2004
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 26
guillotmarc Va por buen camino
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).
Responder Con Cita
  #3  
Antiguo 02-09-2004
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 26
guillotmarc Va por buen camino
Hola.

Cita:
Empezado por AGAG4
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.
Un UNION es para unir varias filas, y no para unir varios campos en una sola fila.

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).
Responder Con Cita
  #4  
Antiguo 02-09-2004
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 26
guillotmarc Va por buen camino
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).
Responder Con Cita
  #5  
Antiguo 02-09-2004
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 26
guillotmarc Va por buen camino
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).
Responder Con Cita
  #6  
Antiguo 02-09-2004
Avatar de AGAG4
AGAG4 AGAG4 is offline
Miembro
 
Registrado: ago 2004
Ubicación: Los Mochis, Sinaloa, México
Posts: 1.420
Poder: 23
AGAG4 Va por buen camino
Post Oki

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.
Responder Con Cita
  #7  
Antiguo 02-09-2004
Avatar de antrax
antrax antrax is offline
Miembro
 
Registrado: ago 2004
Ubicación: Escobedo N.L.Mx
Posts: 10
Poder: 0
antrax Va por buen camino
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]
Responder Con Cita
  #8  
Antiguo 03-09-2004
Avatar de AGAG4
AGAG4 AGAG4 is offline
Miembro
 
Registrado: ago 2004
Ubicación: Los Mochis, Sinaloa, México
Posts: 1.420
Poder: 23
AGAG4 Va por buen camino
Post ????

Gracias de antemano por respondermer, pero no me funciono lo que dice...
Código SQL [-]
SELECT A.MAXIMO,A.TOPELISTA,A.TOPEMAY,B.MINIMO,B.TOPELISTA,B.TOPEMAY 
FROM 
/*Marca Error en Select*/(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
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.
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

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


La franja horaria es GMT +2. Ahora son las 22:08:37.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi