Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 26-10-2006
subzero subzero is offline
No confirmado
 
Registrado: ene 2004
Ubicación: Móntería - Córdoba - Colombia
Posts: 289
Poder: 0
subzero Va por buen camino
Exclamation Consulta SQL algo compleja

Hola foro:

De antemano gracias por Interesarse en mi duda, Bueno, tengo lo siguiente, estoy generando un consulta en Firebird 2.0 en la cual estoy tomando tres tablas con este script.

Código PHP:
SELECT
  E
.EMP_NIT,
  
E.PRO_CODIGO,
  
PT.PRE_CODIGO,
  
MIN((E.EMP_PRO_COSTO - (E.EMP_PRO_COSTO E.EMP_PRO_DESC 100)) / E.EMP_PRO_EMBALAJE) AS TOTAL
FROM
  EMPRESA_PRODUCTO E
  INNER JOIN PRODUCTOS P ON 
(E.PRO_CODIGO P.PRO_CODIGO)
  
INNER JOIN PRESENTACION PT ON (P.PRO_PRE_CODIGO PT.PRE_CODIGO)
GROUP BY
  E
.EMP_NIT,
  
E.PRO_CODIGO,
  
PT.PRE_CODIGO
ORDER BY
  E
.PRO_CODIGO 

y me genera lo siguiente:

Código PHP:
    NIT           CODIGO        PRE      TOTAL 
800042169    0000000003     027      735 
800042169    0000000004     033      700 
8300108781   0000000004     033      450 
800042169    0000000005     064      20 
8300108781   0000000005     064      16.5 
Pués bien, como nos podemos dar cuenta existen códigos que se repiten pero pertenecen a "NIT's" diferentes y puede en ocaciones a "PRE" Presentaciones diferentes, por lo tanto la necesidad es poder escoger el registro con menor valor en el "TOTAL" para que me devuelva algo así:

Código PHP:
    NIT           CODIGO        PRE      TOTAL 
800042169    0000000003     027      735 
8300108781   0000000004     033      450 
8300108781   0000000005     064      16.5 
Como se pueden dar cuenta es escoger el producto mas barato y saber que empresa lo tiene... Agradezco cualquier idea.
Responder Con Cita
  #2  
Antiguo 26-10-2006
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 27
jachguate Va por buen camino
Probá con esto:

Código SQL [-]
SELECT
  E.EMP_NIT,
  E.PRO_CODIGO,
  PT.PRE_CODIGO,
  MIN((E.EMP_PRO_COSTO - (E.EMP_PRO_COSTO * E.EMP_PRO_DESC / 100)) / E.EMP_PRO_EMBALAJE) AS TOTAL
FROM
  EMPRESA_PRODUCTO E
  INNER JOIN PRODUCTOS P ON (E.PRO_CODIGO = P.PRO_CODIGO)
  INNER JOIN PRESENTACION PT ON (P.PRO_PRE_CODIGO = PT.PRE_CODIGO)
GROUP BY
  E.EMP_NIT,
  E.PRO_CODIGO,
  PT.PRE_CODIGO
ORDER BY
  E.PRO_CODIGO
HAVING
  MIN((E.EMP_PRO_COSTO - (E.EMP_PRO_COSTO * E.EMP_PRO_DESC / 100)) / E.EMP_PRO_EMBALAJE) =
  (
    Select min((E2.EMP_PRO_COSTO - (E2.EMP_PRO_COSTO * E2.EMP_PRO_DESC / 100)) / E2.EMP_PRO_EMBALAJE)
      from empresa_producto e2
     where e2.pro_codigo = e.pro_codigo
  )

Si no funciona a la primera, al menos te acerca a la idea.

Hasta luego.

__________________
Juan Antonio Castillo Hernández (jachguate)
Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate
Responder Con Cita
  #3  
Antiguo 26-10-2006
subzero subzero is offline
No confirmado
 
Registrado: ene 2004
Ubicación: Móntería - Córdoba - Colombia
Posts: 289
Poder: 0
subzero Va por buen camino
Gracias, era lo que estaba necesitando.
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
Ventana pop-up o algo asi FullDelphi Varios 3 10-04-2006 08:46:24
Es algo importante ejecución de .exe y algo más ayúdenme kakesoft Varios 5 02-05-2005 10:01:14
Algo parecido al try...except __cadetill PHP 18 10-05-2004 00:03:55
Algo bonito... superhopi Varios 3 08-07-2003 00:29:18
consulta SQL que me resulta compleja j2mg SQL 5 29-05-2003 22:50:13


La franja horaria es GMT +2. Ahora son las 04:57:39.


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