![]() |
AW: Anzahl Monate und Anzahl Wochen seit dem 01.01.0001 ermitteln
Hallo zusammen,
mit der Lösung aus meinem Post #14 war ich mir nicht 100%ig sicher. Ich muss mich aber auf die ermittelte Anzahl an Monaten und Wochen verlassen können! Ich habe dann gesucht und eine Tabelle gefunden, wo die Anzahl der Wochen und die Anzahl der Monate und der jeweilige Tag als Datum drin stehen. Somit hatte ich eine Basis für Reverse Engineering! Dann habe ich eine Test-Unit erstellt und meinen Code gegen die Tabellen-Werte vergleichen lassen. Ich denke, dass DaysBetween() nicht das Beginn- und das Endedatum für den Zeitraum mit zählt. Wurde ja auch schon durch Frühlingsrolle festgestellt. Meine Anwendung von DaysBetween(StrToDate('01.01.0001', … + 2) stimmten im Test mit allen Werten aus der Tabelle überein! Dann habe ich den Ansatz mit dem Julianischen Datum getestet. Danke auch an dieser Stelle für die Hilfestellung von stpolster und Frühlingsrolle!:thumb: Auch dieser Code lieferte keine Abweichungen, wenn ich 4 Tage davon abziehe. Mir ist klar, dass ich ja gegen Werte vergleiche, die "irgendwie" ermittelt werden und ich mich daran anpassen muss. Somit gibt es für mich 2 überprüfte Lösungsansätze. Ich wende in meinem Programm nun die julianische Variante an. Danke nochmals! |
AW: Anzahl Monate und Anzahl Wochen seit dem 01.01.0001 ermitteln
Zitat:
Unter folgender der Annahme: - für jeden Tag des Kalenders existiert genau ein Eintrag in der Tabelle t_kalender mit den Spalten Tag, Monat, Jahr - nicht mehr als 99 Tage je für eine Kombination aus Monat/Jahr - nicht mehr als 99 Monate für ein Jahr Parameter: von_tag von_monat von_jahr bis_tag bis_monat bis_jahr
Code:
Rückgabewerte:
select count(tag) as cnt_tag, count (distinct jahr, monat) as cnt_monat
from t_kalender where ((((:von_jahr * 100 + :von_monat) * 100) + :von_tag) <= (((jahr * 100 + monat) * 100) + tag)) and ((((:bis_jahr * 100 + :bis_monat) * 100) + :bis_tag) >= (((jahr * 100 + monat) * 100) + tag)) cnt_tag Anzahl Tage im Zeitraum cnt_monat Anzahl Monate im Zeitraum |
Alle Zeitangaben in WEZ +1. Es ist jetzt 09:21 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz