AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Mehrerer Datensätze pro Zeitraum generieren
Thema durchsuchen
Ansicht
Themen-Optionen

Mehrerer Datensätze pro Zeitraum generieren

Ein Thema von Jumpy · begonnen am 1. Feb 2015 · letzter Beitrag vom 2. Feb 2015
Antwort Antwort
Jumpy

Registriert seit: 9. Dez 2010
Ort: Mönchengladbach
1.736 Beiträge
 
Delphi 6 Enterprise
 
#1

Mehrerer Datensätze pro Zeitraum generieren

  Alt 1. Feb 2015, 22:14
Datenbank: Oracle • Version: 10g • Zugriff über: ADO
Hallo,

für eine Schnittstelle zu einer komplett anders arbeitenden Software als unsere muss ich historisierte Daten liefern. Dabei liegen bei uns die Historien in Form eines von- und eines bis Datums vor. In der anderen Software gibt es pro Jahr und pro Monat immer einen Datensatz. Ich muss daher einen bei uns mehrere (sagen wir mal 5) Monate gültigen Datensatz 5 mal liefern wobei Monat (und. ggf. Jahr) heraufgezählt werden.

Hat irgendwer eine Idee, wie das per SQL gehen könnte? Im Notfall kann ich das natürlich in der Verarbeitung machen, aber ich kann mir auch eine Tabelle vorstellen, wo das cool wäre wenn dass per SQL ginge.

Somit soll werden aus:

[code]
PNR | VON_____ | BIS______ | IrgendwecheAnderen Datenfelder
123 | 01.01.2014 | 31.05.2014 | Willi Müller ...

soll werden
PNR | Jahr | Monat | IrgendwecheAnderen Datenfelder
123 | 2014 | 01 | Willi Müller ...
123 | 2014 | 02 | Willi Müller ...
123 | 2014 | 03 | Willi Müller ...
123 | 2014 | 04 | Willi Müller ...
123 | 2014 | 05 | Willi Müller ...
[code]
Ralph
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#2

AW: Mehrerer Datensätze pro Zeitraum generieren

  Alt 1. Feb 2015, 22:52
Nun wenn ich Dich richtig verstanden habe, dann wird aus von__ minmonat und bis__ maxmonat.
Und dann
Code:
for i:=minmonat to maxmonat do insert.....
(nein, mit der SQL-syntax steh ich auf Kriegsfuß, darum nagel mich nicht darauf fest)

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#3

AW: Mehrerer Datensätze pro Zeitraum generieren

  Alt 1. Feb 2015, 23:09
Erstelle dir eine Hilfstabelle, die alle Datum vom 1.1.1900 bis zum 31.12.2100 enthält (z.B.). So eine Datedimensiontable ist so fundamental, das es diverse Generierungstools dafür gibt (oder EXCEL Dateien).

Und da Du nun eine entsprechende Tabelle hast, kannst du einfach diese Query ausführen:

SQL-Code:
Select <Daten>
  from DateDimension
       join MeineTabelle on DateDimension.Date between MeineTabelle.MinDatum and MeineTabelle.MaxDatum
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.062 Beiträge
 
Delphi 12 Athens
 
#4

AW: Mehrerer Datensätze pro Zeitraum generieren

  Alt 1. Feb 2015, 23:30
Viele DBMS besitzen bereits Funktionen zum Generieren von "Serien" und wenn nicht, dann kann man sich dort bestimm selber eine passende Funktion selber erstellen, falls sowas nicht schon jemand gemacht hat.

Bei Google suchenoracle generate series
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.

Geändert von himitsu ( 1. Feb 2015 um 23:33 Uhr)
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#5

AW: Mehrerer Datensätze pro Zeitraum generieren

  Alt 2. Feb 2015, 08:03
Das wäre dann sowas o.ä. jenachdem wie der Datumsparameter reinkommt:
Code:
Select 123 as id, 2014 y, Rownum m, 'Willi Müller' as nme From dual
         Connect By Rownum <= to_number(to_char(to_date('31.05.2014', 'DD.MM.YYYY'),'MM'))
Die Generierlösung hat aber ihre Grenzen, wenn Wochenenden, bewegliche Feiertage (oder fehlende bei Ungläubigen usw.), spezifische Arbeitstage des Unternehmens, .. zu berücksichtigen sind. Das wird dann schnell frickelig, auch wenn der Ansatz erstmal bequem scheint.
Da kommt dann doch die Dimension Tabelle von Dejan Vu ins Spiel. Da kann man den ganzen Kram deklarieren, den man berücksichtigen muss und dann je nach Bedarf filtern.
Gruß, Jo
  Mit Zitat antworten Zitat
Jumpy

Registriert seit: 9. Dez 2010
Ort: Mönchengladbach
1.736 Beiträge
 
Delphi 6 Enterprise
 
#6

AW: Mehrerer Datensätze pro Zeitraum generieren

  Alt 2. Feb 2015, 10:14
Erstelle dir eine Hilfstabelle, die alle Datum vom 1.1.1900 bis zum 31.12.2100 enthält (z.B.). So eine Datedimensiontable ist so fundamental, das es diverse Generierungstools dafür gibt (oder EXCEL Dateien).

Und da Du nun eine entsprechende Tabelle hast, kannst du einfach diese Query ausführen:

SQL-Code:
Select <Daten>
  from DateDimension
       join MeineTabelle on DateDimension.Date between MeineTabelle.MinDatum and MeineTabelle.MaxDatum
Danke. Das hört sich doch schonmal gut und einfach an. Ich muss Daten immer Rückwirkend bis zum 1.1. des Vorjahres liefern, brauche somit also 13-24 Monate in der DateDimension Tabelle. Ich denke ich werde diese DateDimension-Tabelle als Temptable bei jedem Verarbeitungslauf (1x monatl.) neu mit den richtigen Dimensionen erstellen oder den aktuellen Monat einfach hinzufügen, mal schauen.
Ralph
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#7

AW: Mehrerer Datensätze pro Zeitraum generieren

  Alt 2. Feb 2015, 15:12
Ich würde diese Tabelle einmalig erstellen. Überleg mal: 10000 Zeilen und Du bist für die nächsten 30 Jahre safe. Die Tabelle enthält (bzw. kann) ja auch sehr nützliche Informationen über Wochentag, Tag des Jahres etc. Sowas baust Du dir einmal und hast dann das für alle Projekte. So eine Tabelle passt einfach immer. Du kannst sie peu à peu erweitern.

Und wie gesagt: Tools, die Dir so eine Tabelle bauen, gibt es wie Sand am Meer. Du kannst dort z.B. auch Betriebsversammlungen einpflegen oder Betriebsstörungen etc. Dann versaut dir das nicht mehr die Statistik.
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 09:11 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz