AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Wie am besten speichern?
Thema durchsuchen
Ansicht
Themen-Optionen

Wie am besten speichern?

Ein Thema von the_seed · begonnen am 1. Dez 2010 · letzter Beitrag vom 2. Dez 2010
Antwort Antwort
the_seed

Registriert seit: 31. Dez 2003
213 Beiträge
 
#1

Wie am besten speichern?

  Alt 1. Dez 2010, 15:06
Datenbank: ? • Version: ? • Zugriff über: ?
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
  Mit Zitat antworten Zitat
Benutzerbild von jfheins
jfheins

Registriert seit: 10. Jun 2004
Ort: Garching (TUM)
4.579 Beiträge
 
#2

AW: Wie am besten speichern?

  Alt 1. Dez 2010, 16:47
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
  Mit Zitat antworten Zitat
jobo

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

AW: Wie am besten speichern?

  Alt 2. Dez 2010, 10:33
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.
  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 18:09 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