![]() |
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, 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. |
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 |
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. |
La franja horaria es GMT +2. Ahora son las 09:12:32. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi