AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Aufbau einer Währungstabelle

Ein Thema von DSP · begonnen am 20. Jan 2015 · letzter Beitrag vom 25. Jan 2015
Antwort Antwort
Seite 1 von 2  1 2      
DSP

Registriert seit: 10. Jul 2014
49 Beiträge
 
#1

Aufbau einer Währungstabelle

  Alt 20. Jan 2015, 17:32
Tach Zusammen,

weiss grad nicht wo das Tehma hingehört, vielleicht hier oder in den Bereich der Datenbanken. Aber ich versuche es mal hier

Wollte ganz gerne in SQLite eine Währungstabelle anlegen, mit folgenden Aufbau:
{@Datum;@Kurstyp;@Währung_Von;@Währung_Nach;Kurs}
Jetzt wollte ich gerne performant und auch häufig die Tabelle abfragen. Dabei tritt das Problem auf, dass ich nicht weiss wann der letzte Eintrag in der Tabelle vorhanden ist. Daher die Frage an Euch, wie würdet ihr so eine Abfrage/Tabellendesign am besten gestallten, dass man auch bei vielen Einträgen mit möglichst geringen Kosten auskommt und der gültige Datensatz zuverlässig geliefert wird?

Schon mal vielen Dank für die Tipps
DSP
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#2

AW: Aufbau einer Währungstabelle

  Alt 20. Jan 2015, 18:13
Wer trägt denn die Daten in die Tabelle ein? Doch wohl die gleiche Anwendung.

Generell würde ich hier den gesamten Verhau grundsätzlich lösen.

Einen Wert-Typ für die Währung
Einen Wert-Typ für die Umrechnung
Einen Wert-Typ für den Währungsbetrag
Ein Repository für die Werte
Einen Umrechner der einem Währungsbetrag in eine andere Währung umrechnen kann

Ein Repository wird immer als Interface ausgelegt, dadurch kann man sehr schön auch einen Proxy/Cache dazwischenschalten, der hier in diesem Fall z.B. die Werte zwischenspeichert, so dass für jeden Wert nur eine Abfrage an die Datenbank geht und alle weiteren werden aus dem Cache bedient.

Wenn ich etwas Zeit finde, kann ich da mal ein Konstrukt zusammenbauen
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
jobo

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

AW: Aufbau einer Währungstabelle

  Alt 21. Jan 2015, 07:36
Generell würde ich hier den gesamten Verhau grundsätzlich lösen.

Einen Wert-Typ für die Währung
Einen Wert-Typ für die Umrechnung
Einen Wert-Typ für den Währungsbetrag
Ein Repository für die Werte
Einen Umrechner der einem Währungsbetrag in eine andere Währung umrechnen kann
Wenn ich die Anforderung richtig geahnt hab, ist hier noch das Datum im Spiel, also historisierte Daten, also Kursverläufe. Es wäre also ein gegebenes Eintragsdatum zu berücksichtigen und bei der Abfrage eine Vorschrift, die aus dem gewünschten Zeitpunkt und den nächsten vorhandenen Werten in der Historie einen definierten Wert ausspuckt (nächster, voriger, Mittelwert daraus, ...)
Gruß, Jo
  Mit Zitat antworten Zitat
DSP

Registriert seit: 10. Jul 2014
49 Beiträge
 
#4

AW: Aufbau einer Währungstabelle

  Alt 21. Jan 2015, 08:51
Hallo Zusammen,

danke für die Hilfe, das Hauptproblem das sich für mich darstellt, wie kann man am effizientesten auf den aktuellen Datensatz zugreifen, wenn man den Schlüssel nicht kennt? Dazu kommt noch, dass das Rücklesen auch nicht besonderes gut ist, da es ggf auch zuvor keine Datensätze gibt. Der Anwender kann zur Umrechnung prinzipiell jedes mögliche Datum eingeben. Hier ist eben die Frage, wie man das am effizientesten lösen kann.

Schon mal vielen Dank
DSP
  Mit Zitat antworten Zitat
hstreicher

Registriert seit: 21. Nov 2009
223 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#5

AW: Aufbau einer Währungstabelle

  Alt 21. Jan 2015, 09:58
Welche Felder haben denn einen Index ?

ggf auf die Typisch abgefragten Felder einen Index anlegen
  Mit Zitat antworten Zitat
jobo

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

AW: Aufbau einer Währungstabelle

  Alt 21. Jan 2015, 10:24
das Hauptproblem das sich für mich darstellt, wie kann man am effizientesten auf den aktuellen Datensatz zugreifen, wenn man den Schlüssel nicht kennt? Dazu kommt noch, dass das Rücklesen auch nicht besonderes gut ist, da es ggf auch zuvor keine Datensätze gibt. Der Anwender kann zur Umrechnung prinzipiell jedes mögliche Datum eingeben. Hier ist eben die Frage, wie man das am effizientesten lösen kann.
Was meinste Du mit "..auf den aktuellen Datensatz zugreifen.."?
Den zuletzt eingegebenen, weil es doch nur um aktuelle Wechselkurse geht?
Oder doch quer Beet ("der anwender kann ..jedes mögliche Datum eingeben..")?
Also ich vermute nochmal, dass ggF. Werte historisiert vorliegen und dass das abgefragte Datum bzw. der Kurs zu dieser Zeit exakt so wie abgefragt bestenfalls zufällig vorhanden ist.
Mglw. wäre hier ein Ansatz:
Code:
select * from wechselkurshistorie
where ..siehe unten bei DeddyH
Jenachdem ob was rauskommt oder nicht, muss noch geprüft werden, ob nur eine Bedingung erfüllt ist (möglicher Treffer ganz am Anfang oder Ende)
Weiter muss eingeschränkt werden, welche beiden Währungen den Kurs definieren (2 Fremdschlüssel?, also 2 weitere Einschränkungen im where bzw.Joins)
Was meinst Du mit Rücklesen?
Gruß, Jo

Geändert von jobo (21. Jan 2015 um 10:42 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.655 Beiträge
 
Delphi 12 Athens
 
#7

AW: Aufbau einer Währungstabelle

  Alt 21. Jan 2015, 10:30
Ich hätte eher so gedacht (ungetestet):
SQL-Code:
SELECT
  *
FROM
  wechselkurse
WHERE
  Datum = (
    SELECT
      MAX(Datum)
    FROM
      wechselkurse
    WHERE
      Datum <= :Abfragedatum
  )
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
DSP

Registriert seit: 10. Jul 2014
49 Beiträge
 
#8

AW: Aufbau einer Währungstabelle

  Alt 24. Jan 2015, 18:52
Hallo Zusammen,

vielen Dank für die Unterstützung. Ich denke, ich werde die Deddy Variante verwenden, da sie mir am performantesten vorkommt. Keine zusätzliche Ergebnistabelle, welche zu sortieren und abzuarbeiten ist.

Code:
SELECT
  *
FROM
  wechselkurse
WHERE
  Datum = (
    SELECT
      MAX(Datum)
    FROM
      wechselkurse
    WHERE
      Datum <= :Abfragedatum
  )
Das Tabellenwerk werde ich mir mit einem ORM realisieren, da ist dann das Tabellenwerk direkt im ORM gekapselt und wenn man dann die Währungsfunktionalität benötigt, reicht es praktisch eine Unit in den Code einzubinden.

Ob man dann über eine Basiswährung geht oder und wie man die Faktoren behandelt, sind dann nur kleine Implementierungsdetails.

Grüsse
DSP
  Mit Zitat antworten Zitat
mensch72

Registriert seit: 6. Feb 2008
838 Beiträge
 
#9

AW: Aufbau einer Währungstabelle

  Alt 25. Jan 2015, 10:37
Bei den Wechselkursen hin&her ist hier leider ein entscheidender Fakt vergessen worden:
An- & Verkaufskurs sind immer UNTERSCHIEDLICH. Zu erfassen sind also immer ein Geldkurs & ein Briefkurs, auch als Bid/Ask bekannt.

Wenn es genau werden soll/muss, zählt auch die Uhrzeit. Denn alles vor dem (EZB)Fixing wird zum Vortageskurs abgerechnet, alles danach zum "Tageskurs"


Leider funktioniert auch das Beispiel mit der Wechselorgie im Dreieck nicht so einfach, das man es sich machen ließe, wen der vermeintliche Ertrag Positiv ist...
Erstens fehlt hier gleich 2x oder 3x der Bid/Ask-Spread plus der Aussführungsspread/Transaktionsgebühren. Zweitens braucht es zum historischen prüfen eine gute(teure) Kurshistory mit einer sehr hohen Zeitauflösung(im Idealfall bis Millisekunden) und zur Liveausführung einer möglichen Transaktion eine schnelle automatische Orderausführung.


Für eine Lagerbestandsbewertung oder für eine Rechnungsstellung in Fremdwährung reicht so eine "einfache" Kursdatenbank eventuell, aber man sollte wissen wo die Grenzen des Konzepts liegen. Umgedreht wäre eine Lösung mit z.B. 300Mio Datensätzätzen für alle auf die Millisekunde genau erfassten EUR/USD Transaktionen der letzten 10Jahre total OverSized, wenn ein einfacher Tageskurs reicht. (zufällig kenne/habe ich beides, und weiß das sobald die Zeit sekundengenau über Zeitzonen hinweg ins Spiel kommt, der Spaß aufhört und es ernst wird)

-> man schaue in sein Pflichten-/Lastenheft und prüfe, welche Anforderung an Live Genauigkeit und historische Reproduziebarkeit notwendig bzw. sinnvoll ist
=> erst dann lässt sich die Frage nach dem sinnvollem Aufbau einer Währungstabelle samt passender (ORM)Klassenstruktur praktisch beantworten
-> eine lokale Kurshistory als Cache ist ok, aber zum Füllen der History sollte man online die Kurse abfragen. Für Tageskurse gibt es kostenlose (Web)Services, für komplette Historien oder zeitnahe bis zu Realtime Kursen gibt es kaum kostenlose Quellen, aber gegen Geld gibt es für jede Anforderung irgendwo ein passendes Datenabo.
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#10

AW: Aufbau einer Währungstabelle

  Alt 25. Jan 2015, 11:01
Deine Ausführungen (bis auf bid/ask) gelten aber nur zum Daytraden, oder?
Das Bankensystem, das wir betreuen, enthält eine Währungstabelle, die 'nur' täglich aktualisiert wird.
Ggf. kann man sich den Kurs auch online holen.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 06:24 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 by Thomas Breitkreuz