Club Delphi  
    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 23-09-2004
Ignacio Ignacio is offline
Miembro
 
Registrado: may 2003
Posts: 77
Poder: 21
Ignacio Va por buen camino
Sumar un campo en dos tablas

Tengo un problema al querer sumar cantidades correspondientes a un mismo artículo dentro de dos tablas.
Tablas:
Articulos: Contiene el stock general
Retiros: son movimientos de rertiro del stock gral y va dando forma al subStock.
Aplicaciones: Son movimientos de uso del subStock. Si sumo los retiros y le resto las aplicaciones obtengo el subStock.

Cada registro de las tablas "Retiros" y "Aplicaciones" están identificados con un campo que contiene el numero de Articulo y un campo que contiene el numero de depósito.

Mi intencion es obtener un listado de artículos acompañado de su subStock dentro de un depósito.
Esto implicaría que por cada artículo sume lo retirado y le reste lo aplicado.

el código SQL intentado -que está mal- es el siguiente
Código:
Select NumeroART,
         NombreART,
         Sum(CantretiradaRET) as Cantretirada,
         Sum(CantaplicadaAPL) as Cantaplicada
From Articulos
Left Outer Join Retiros on (ArticuloRET=NumeroART)
Left Outer Join Aplicaciones on (ArticuloAPL=NumeroART)
Group by NumeroART, NombreART
Si uso "Left Outer" me suma (por ejemplo) tres veces una aplicación si es que ese artículo tiene tres retiros. Y viceversa. En cambio si uso "Inner" no me suma (por ejemplo) las aplicaciones si ese artículo no tuvo retiros.
Para chequear el error reemplazo todo el Select por Select * y efectivamente las cantidades estan repetidas o faltan segun el caso del "Join".

Usar "Union" no me sirve porque los artículos se verían dos veces. Una por los retiros y otra por las aplicaciones.

Espero haber descripto bien mi problema. Desde ya, muchas gracias.
Responder Con Cita
  #2  
Antiguo 23-09-2004
maritza maritza is offline
Registrado
 
Registrado: sep 2004
Posts: 1
Poder: 0
maritza Va por buen camino
Sumar un campo en dos tablas por medio de Subquerys

Hola Ignacio:
Analizando tu problema , creo que podria solucionarse con subquerys, quedando de la siguiente manera:

Código:

SELECT NumeroART,
NombreART,
( (SELECT sum(CantRetiradaRET) FROM Retiros
WHERE Retiros.ArticuloRET = Articulos.NumeroART)
-
(SELECT sum(CantaplicadaAPL) FROM Aplicaciones
WHERE Aplicaciones.ArticuloAPL = Articulos.NumeroART)
) SUbStock
FROM Articulos
GROUP BY NumeroART,NombreART

Saludos

maritza
Responder Con Cita
  #3  
Antiguo 27-09-2004
Ignacio Ignacio is offline
Miembro
 
Registrado: may 2003
Posts: 77
Poder: 21
Ignacio Va por buen camino
Gracias Maritza de todos modos y antes que nada disculpame por la demora de mi respuesta.
Tu sugerencia ya la había probado y no funciona (al menos en tablas Paradox), que hubiera sido lo ideal.
Me las arreglé con un Qry para Retiros y otro para Aplicaciones, despues recorro el primero y su contenido lo cargo en Un RxMemoryData, luego recorro el segundo Qry y por cada registro chequeo si ya está cargado en el RxMemoryData, en ese caso edito el registro y cargo la cifra de Aplicaciones, pero si no existiera, le inserto un nuevo registro y cargo todo completo. No es lo óptimo pero me sacó del paso.

Chau. nos vemos.
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 20:06: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