Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Wie am besten speichern? (https://www.delphipraxis.net/156422-wie-am-besten-speichern.html)

the_seed 1. Dez 2010 15:06

Datenbank: ? • Version: ? • Zugriff über: ?

Wie am besten speichern?
 
Hallo zusammen, ich hoffe ihr könnt mir bei einem Gedanken weiterhelfen.
Ich suche die bestmöglichste Lösung für folgende Aufgabe.

Ich möchte ein Programm entwickeln welche verschiedene "Telegramme" in die einzelnen Bestandteile auflöst.

Beispieltelegramm: AB01PP555xyzabcdZZZ

AB = Absender
01 = Empfänger
PP = Identifikation
555 = Datenteil A
xyz = Datenteil B
abcd = Datenteil C
....

Es gibt etwa 1000 verschiedene Telegramme mit unterschiedlicher Länger und variablen Dateninhalt - diese werden anhand ihrem Absender/Empfänger sowie ID unterschieden.

Das Programm soll nun anhand der Eingabe eines beliebigen Telegramms den Typ und die Bezeichnungen deklarieren und ausgeben.
Meine Datenbankkentnisse sind relativ beschränkt und ich weiss nicht so recht wie genau ich die Masse an Telegramm Daten speichern soll.

habe schon an ini datei oä. gedacht in form von

[Telegram0100]
DatenteilA=3
DatenteilB=3
....

Das quasi linker teil die beschriftung und rechter teil die anzahl an stellen darstellt??



Vielleicht kann mir ja jemand helfen :-)

jfheins 1. Dez 2010 16:47

AW: Wie am besten speichern?
 
Du könntest in der datenbank auch eine Spalte mit dem Namen und eine mit einem regulären Ausdruck machen. Dann gehst du einfach die ganzen reg. Ausdrücke durch und prüfst, ob sie auf den Text passen.
Dann kannst du z.B. noch eine zusätzliche Spalte machen in der die Bezeichnungen der einzelnen Teile aufgeführt sind (mit pipes getrennt) die du im regExp durch Klammern gruppieren kannst.

Wenn's schnell gehen soll und deine Datenfelder eine konstante Länge haben, kannst du auch noch eine Spalte mit der Länge des Telegramms machen. Dann brauchst du für alle anderen Typen nicht mehr den RegExp checken.

pro Telegrammtyp dann natürlich eine Zeile

jobo 2. Dez 2010 10:33

AW: Wie am besten speichern?
 
Ich würde in jedem Fall mit einer Datenbank arbeiten, um leistungsfähige Selections-, Transformationsmechanismen von SQL nutzen zu können.
Das ist sauber zu erweitern bei neuen Telegrammen und Du vermeidest Chaos-Code im Client, der die 1000 Telegramme "auswertet".

Angenommen, deine Telegrammbeschreibung für Absender-Empfänger-ID ist fest in der Länge
und die Anzahl(!) der Datenteile mit variabler Länge ist ebenfalls fest (zumindest nicht zu stark schwankend), dann:
- kannst Du eine Tabelle anlegen, die als Primärschlüssel "Absender-Empfänger-ID", also z.b. AAEEID nutzt.
- trägst Du darin alle Schlüssel für die 1000 Telegramme ein.
- pro Datenteil noch jeweils eine Spalte mit der Länge in die Tabelle einbauen
- erhälst Du also 4 Spalten in der Matrix, z.B.: pk, DataSizeA, DataSizeB, DataSizeC
gemäß deines Beispiels wäre der Eintrag 'AB01PP',3,3,4
(denkbar wären noch weitere Spalten, die einen einfachen Datentyp angeben Text/Zahl, ...)

Nun kannst Du eingehende Telegramme bequem per SQL auswerten und weiterverarbeiten.
Pseudo SQL
Code:
  :P='AB01PP555xyzabcdZZZ' -- 'Parameter p mit auszuwertendem Telegramm
  Select
    substr(:p, 1, 2) as Absender,
    substr(:p, 3, 2) as Empfaenger,
    substr(:p, 5, 2) as TeleGrammID,
    substr(:p, 7, DatasizeA) as DataPartA,
    substr(:p, 7 +DatasizeA, DatasizeB) as DataPartB,
    substr(:p, 7 +DatasizeA +DatasizeB, DatasizeC) as DataPartC,  
  from TelegramMatrix where pk=substr(:p,1,6)
Wenn das Telegrammgerüst nicht so starr ist, wie in Deinem Beispiel kommst Du wohl an regulären Ausdrücken nicht vorbei.
Wenn Du auf reguläre Ausdrücke stehst und es Regelmäßigkeiten bei den 1000 Definitionen gibt, kannst du Dir damit vielleicht etwas Tipparbeit sparen.


Alle Zeitangaben in WEZ +1. Es ist jetzt 12: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