"Das ist in der Praxis aber natürlich nicht der Fall."
Das kann ich bestätigen, da nicht jeden Monat eine Bewegung entstehen muss und der letzte Bestand durchaus schon Jahre da rumliegen kann.
Vor Jahr(zehnt)en habe ich mal eine Anfangsbestandsermittlung bezogen auf ein Datum geschrieben:
Code:
select lbfirm, lbwknr, lbtenr, lblanr
,max(digits(lbdate) concat digits(lbtime) concat digits(lbrfnr) concat ';' concat char(lblgbe) concat ';' concat char(lbprei) concat ';' concat char(lbmeng) ) as lbbest
from lgbw
where lbfirm=? and lbwknr=? and lbdate < ? and lbtenr<>' ' and lbmeng <> 0
group by lbfirm, lbwknr, lbtenr, lblanr"
Durch die Max-Funktion erhält man das letzte Datum (Zeit+ ID) und durch die Concat's alle benötigten Werte auf dieses Datum.
Im Ergebnis muss ich die Inhalte dann nur wieder trennen.
Es würde auch reichen, nur die LBRFNR mit aufzunehmen und damit wieder einen Join durchzuführen.
Nun kann man die Bestände zu jedem beliebigen Stichtag ermitteln.
Bookmarks