Hola expertos espero esten muy bien, siempre es un gusto saludarlos y saber que siempre estan ahi para ayudar a ser mejores programadores.
Les quiero mostrar el codigo sql que utilizo en un sistema de inventarios multialmacen con punto de venta, me sirve para actualizar el campo 'existe' de una tabla llamada 'tab_stock' la cual me dice la cantidad existente por producto y por almacen, esta consulta se enlaza con otra tabla que se llama 'venta' donde se guardan las ventas registradas en los puntos de venta, la consulta cambia un poco solo en la ultima condicion 'WHERE' dependiendo el proceso en el que se encuentre por ejemplo esta que muestro es cuando estamos en un proceso de compra y solo actualizo los productos que estoy comprando o dandole entrada al almacen, pues bien mi cuestion es si alguien me entiende y me pueda decir si el metodo que utilizo es bueno o malo o si conocen una mejor manera de hacerlo poder cambiarlo aun funcionandome bien hasta ahora. utilizo delphi7 y MySQL(adoconnection MyODBC, MySQL Workbench 5.2)
.
Código SQL
[-] update tab_stock ts set ts.existe=(SELECT
SUM( If( tipo_mov =1, cantidad, 0 ) )+
SUM( If( tipo_mov =2, cantidad, 0 ) )-
SUM( If( tipo_mov =3, cantidad, 0 ) )-
(select IF(sum(cantidad)>0,sum(cantidad),0) from venta v where v.id_almacen=:ida and v.id_producto=ts.id_producto)-
SUM( If( tipo_mov =5, cantidad, 0 ) )+
SUM( If( tipo_mov =6, cantidad, 0 ) )+
SUM( If( tipo_mov =7, cantidad, 0 ) )-
SUM( If( tipo_mov =8, cantidad, 0 ) )+
FROM tab_detalle_compra tdc
WHERE tdc.id_almacen=:ida
AND tdc.id_producto=ts.id_producto)
WHERE ts.id_almacen=:ida
AND ts.id_producto IN(select id_producto from tab_detalle_compra where id_compra=:idc))
muchas gracias amigos espero sus comentarios