Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > SQL
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

 
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 28-04-2010
Rom@n Rom@n is offline
Miembro
 
Registrado: oct 2007
Posts: 25
Poder: 0
Rom@n Va por buen camino
Smile sentencia sql para el control de existencias de un sistema de inventarios multialmace

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
Responder Con Cita
 



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
Sistema de control en tiempo real FGarcia Varios 2 15-08-2008 16:30:15
duda sobre control de existencias de articulos gmontes Firebird e Interbase 7 10-01-2006 02:28:45
Sugerencia para un módulo de Inventarios JorgeBec Varios 2 10-12-2005 22:04:28
Proyecto de un sistema de facturacion y control de pasientes estebanx Varios 2 16-12-2004 21:50:02
sentencia sql para access aip Conexión con bases de datos 2 17-02-2004 19:18:52


La franja horaria es GMT +2. Ahora son las 03:57:29.


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