![]() |
Campos Calculados en base un registro anterior al actual
Campos Calculados en base un registro anterior al actual
Estoy haciendo la típica tabla contable DEBE | HABER | SALDO Siendo SALDO, un campo calculado en base al DEBE y el HABER. Pero no se como hacer para calcularlo y mostrarlo como se debe, como en la vieja escuela. Porque? Porque si bien el saldo se obtiene directamente desde la operación con DEBE y HABER, necesito que, partiendo del primer registro de la tabla, los siguientes SALDOS, se calculen en base al arrastre de cuentas, es decir, supongamos que tengo: ID | DEBE | HABER | SALDO --------------------------- 1..........2..........0.......-2 2..........5..........0.......-7 3..........8..........0.......-15 4..........0..........5.......-10 etc. Puedo hacer el DEBE-HABER cuando calculo el campo, pero como hago para que me arrastre el SALDO anterior? no se me ocurre. Saludos y gracias |
seria algo como la suma de los DEBE menos la suma de los HABER.
siempre que el sean ID's menores o iguales a mi ID. |
bueno, se me ocurre una subconsulta, algo asi como:
a lo mejor algo me falla pero creo que ahi esta la idea... |
Si, la idea podria ser, pero el tema esta que la consulta, si o si, tiene que estar ordenada por FECHA.
|
Cita:
|
Sobre el ordenamiento, podrías ordenarla tal como te plazca:
El inconveniente que veo de enfrentar el problema con esta solución es el rendimiento. En bases de datos pequeñas, no habrá diferencia, pero en bases de datos grandes indudablemente no lo dejaría. Lamentablemente no sabemos el motor sobre el que se ejecutará, por lo que, ceñidos al estándar, no veo otra opción que esta. Hasta luego. ;) |
SOLUCIONADO
Corregí la clausula where, ya que es lo correcto. Porque? que pasa si añadiera un registro cuya fecha es anterior? al estar ordenado por ID, este seria mayor en un registro posterior.
Saludos |
La franja horaria es GMT +2. Ahora son las 10:42:11. |
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