FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
|||
|
|||
campos calculados, hacen los que se les antoja¡¡¡
hola a todos
nesecito ayuda con los campos calculados, este es mi codigo: procedure TFormInven.CInvenDiaCalcFields(DataSet: TDataSet); begin Inv:=Inv+CInvenDia.FieldByName('Venta').AsInteger+CInvenDia.FieldByName('Salidas').AsInteger+ CInvenDia.FieldByName('Entradas').AsInteger; CInvenDia.FieldByName('Inventario').AsInteger:=Inv; end; donde la variable Inv es global de tipo longint, la primera vez lo calcula bien, el problema es cuando se llega al final o al inicio del dbgrid que es donde vuelve a calcular de nuevo la columna calculada Inventario y como inv ya no tiene el valor real calcula en base a otro numero, y esto no es todo la misma consulta la mando a un qreport y todoavia peor ya que aquí ni siquiera imprime los valores que estoy viendo en pantalla manda otros completamente distintos. alguien podria decirme como hacerle para que no este recalculando los campos calculados cada que se le antoje, es decir, lo haga solo una vez, si no es posible como saber cuando se inicia el calculo para volver a iniciar el valor de inv. NB. cabe mencionar que el valor de la variable inv es inicializado con el valor que me regresa otra consulta. gracias por su atencon y se agradece cualquier sugerencia. |
#2
|
||||
|
||||
El uso de campos calculados no es recomendable para "arrastrar" valores que dependen de otros registros de la tabla/consulta, ya que delphi recalculará los campos con bastante frecuencia y a su discresión. Por ello, si queres llevar un dato de este tipo, es mejor que te valgas de algún mecanismo de la base de datos. Si usas interbase/firebird, por ejemplo, podes hacer el cálculo en un StoredProcedure, y te evitas el uso de campos calculados en delphi.
Hasta luego.
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
#3
|
|||
|
|||
gracias.
El detalle es que estoy usando access por medio de ODBC's. Otra cosa que habia pensado es, como les habia comentado que el valor de la variable "inven" viene dado de otra consulta tendria que estar ejecutando dicha consulta para que me de el valor de inven para cada fecha, pero esto se me hace poco practico y eficiente ya que la consulta puede tener cientos de registros con lo cual dicha consulta se ejecutaría muchas veces. Los datos que me devuelve la consulta son Inicialmente el inventario al 01/01/04 es de 100 pzas (inven=100) FECHA VENTAS ENTRADAS SALIDAS INVENTARIO 01/01/04 -54 100 0 146 02/01/04 -40 0 -10 196 ..........................asi sucesivamente y todo depende del valor inicial de la variable inven para el campo calculado INVENTARIO |
#4
|
|||
|
|||
alguien sabe si existe alguna forma de activar y/o desactivar el calculo de campos campos calculados para que el calculo se de solo si esta activado?
|
#5
|
||||
|
||||
Tienes la propiedad AutoCalcFields que puedes poner a falso.
Un Saludo.
__________________
Guía de Estilo de los Foros Cita:
|
#6
|
|||
|
|||
me parece logico que asi fuera pero lo probe y de todas formas sigue autocalculando los valores aun cuando la propiedad AutoCalcFields esta en falso
gracias de todas formas, seguiere intentando. |
|
|
|