Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Conexión con bases de datos
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Conexión con bases de datos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 15-04-2004
agova agova is offline
Miembro
 
Registrado: may 2003
Posts: 69
Poder: 22
agova Va por buen camino
Angry 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.
Responder Con Cita
  #2  
Antiguo 15-04-2004
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 28
jachguate Va por buen camino
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
Responder Con Cita
  #3  
Antiguo 15-04-2004
agova agova is offline
Miembro
 
Registrado: may 2003
Posts: 69
Poder: 22
agova Va por buen camino
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
Responder Con Cita
  #4  
Antiguo 15-04-2004
agova agova is offline
Miembro
 
Registrado: may 2003
Posts: 69
Poder: 22
agova Va por buen camino
Question

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?
Responder Con Cita
  #5  
Antiguo 15-04-2004
Avatar de marcoszorrilla
marcoszorrilla marcoszorrilla is offline
Capo
 
Registrado: may 2003
Ubicación: Cantabria - España
Posts: 11.221
Poder: 10
marcoszorrilla Va por buen camino
Tienes la propiedad AutoCalcFields que puedes poner a falso.

Un Saludo.
__________________
Guía de Estilo de los Foros
Cita:
- Ça c'est la caisse. Le mouton que tu veux est dedans.
Responder Con Cita
  #6  
Antiguo 15-04-2004
agova agova is offline
Miembro
 
Registrado: may 2003
Posts: 69
Poder: 22
agova Va por buen camino
Angry

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



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 06:05:13.


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