Paradox (Datenbank)

aus Wikipedia, der freien Enzyklopädie
(Weitergeleitet von ObjectPAL)
Zur Navigation springen Zur Suche springen
Paradox
Basisdaten

Entwickler Corel
Erscheinungsjahr 1985
Aktuelle Version 11.0.0.676
(April 2016)
Betriebssystem Windows
Kategorie Datenbank
Lizenz Proprietär
deutschsprachig ja
WordPerfect

Paradox ist eine Datenbank-Entwicklungsumgebung bzw. ein dateibasiertes Datenbankformat der Firma Borland bzw. Corel, welches dBASE III, dBASE 3+ und dBASE IV sehr ähnlich und seit den 1980er Jahren auf dem Markt erhältlich ist.

Aufbau[Bearbeiten | Quelltext bearbeiten]

Datenbank[Bearbeiten | Quelltext bearbeiten]

Paradox ist für den Betrieb mit der Borland Database Engine (BDE) vorgesehen. Diese ist selbst nicht Teil von Paradox, sondern eine eigenständige Bibliothek und wird in vielen anderen Softwareprodukten eingesetzt.

Die BDE stellt den Zugriff auf eine relationale Datenbank als Datenbankschnittstelle bereit. Im Falle von Paradox als Datenbankformat belegt dabei jede Tabelle (*.DB) und jeder Index eine (Primärindex *.PX) bzw. zwei (pro Sekundärindex jeweils *.XG? und *.YG?) eigene Datei(en). Enthält eine Tabelle Memo-Felder, Gültigkeitsprüfungen oder Formatierungsinformationen, werden diese ebenfalls in speziellen Files (*.MB, *.VAL, *.TV) abgelegt. Beim Mehrbenutzerbetrieb liegen diese Dateien auf einem Netzlaufwerk, während die BDE-Instanzen der teilnehmenden Rechner den gemeinsamen Zugriff miteinander durch eine Netzsteuerdatei („PDOXUSRS.NET“) und Sperrdateien (*.LCK) koordinieren. Paradox bzw. die DB-Engine beherrscht sogenanntes „Record-Locking“ (Sperren einzelner Datensätze) und ist daher – im Gegensatz zu Mitbewerbern wie etwa Microsoft Access – besser für Mehrbenutzerbetrieb geeignet.

Benutzerschnittstelle[Bearbeiten | Quelltext bearbeiten]

Kernfunktionalität von Paradox sind die Formulare. Das sind Windows-Fenster, die man mit Hilfe der (kostenpflichtigen) Entwicklerversion durch Platzieren von vorgefertigten Eingabe- und Bedienelementen entwirft. Hierdurch entstehen Bildschirmmasken zum Betrachten und Eingeben von Daten.

Eine Programmierung im Sinne von Programmcode-Zeilen ist hierbei nicht erforderlich. Das Laden, Sperren und Speichern von Datensätzen besorgt die Paradox-Laufzeitumgebung automatisch.

Eine weitere Benutzerschnittstelle sind die sogenannten Reports. Sie werden in ähnlicher Weise konstruiert wie die Formulare, dienen aber nicht der Bildschirmdarstellung, sondern zum formatierten Ausdrucken.

Ein Formular belegt je eine Datei, ebenso ein Report.

Scriptsprache[Bearbeiten | Quelltext bearbeiten]

Zu fast allen Ereignissen (etwa Eingaben, Blättern oder Mausklicks) kann Programmcode hinterlegt werden, der die Paradox-eigene Abarbeitung des Ereignisses in beliebiger Weise verändert. Beispielsweise kann man beim Ereignis „Speichern“ unstimmige Daten erkennen, eine Meldung ausgeben und die Speicherung abbrechen. In modernen Begriffen kann man dies als Scriptsprache bezeichnen.

In Paradox steht als Scriptsprache die Paradox Application Language (PAL) bzw. ObjectPAL (in den Windows-Versionen) zur Verfügung. ObjectPAL ist die objektbasierte Variante von PAL (es wird hier bei Paradox korrekt zwischen objektbasiert und objektorientiert unterschieden). Beide sind von Pascal abgeleitet.

Oft wird die Scriptsprache unscharf ebenfalls als „Paradox“ bezeichnet.

Anwendungsprogrammierung[Bearbeiten | Quelltext bearbeiten]

Paradox-Anwendungen werden in einen Zwischencode kompiliert. Zum Ablauf dieser Programme ist weiterhin ein Paradox-System oder eine (kostenfreie) Paradox-Runtime notwendig. Im Gegensatz zu etwa Access muss durch die Teilkompilierung der Quellcode nicht weitergegeben werden.

Versionsgeschichte[Bearbeiten | Quelltext bearbeiten]

Paradox für Windows 1.0 erschien Anfang 1993. Aus Marketinggründen wurde die Version 1.1 im Jahre 1994 als Version 4.5 auf den Markt gebracht – da Paradox für DOS bei diesem Versionsstand war. Das Paradox-Tabellenformat wird daher bei Paradox für Windows 1.0 und 4.5 auch bis Level 4 unterstützt. Paradox für Windows 5.0 war dann die eigentliche zweite Generation (Paradox Table Level 5). Danach kam Paradox 7 in einer Version für Windows 16-Bit und Windows 32-Bit („Table Level 7“ – der letzte Formatstand). Das Produkt Paradox wurde nach Version 7 für Windows an Corel abgegeben (erste Version von Corel ist Corel Paradox 8). Corel integrierte das Programm in die Professional-Versionen seiner WordPerfect Office Suite. Es wurde in den Versionen 9, 10, 11, 12, X3, X4, X5, X6, X7, X8 und X9 der Office-Suite veröffentlicht. Die aktuell von Corel herausgegebene Paradox-Version gibt es nur in Verbindung von Word Perfect Professional X9.[1][2] Die letzte deutsche Version ist Paradox 9.

Sicherheit[Bearbeiten | Quelltext bearbeiten]

Der Inhalt von unverschlüsselten Paradox-Tabellen ist mit paradoxfremden Mitteln, auch mit einfachen Textverarbeitungsprogrammen, zu lesen. Das Paradox-Programm bietet die Möglichkeit, Tabellen zu verschlüsseln, sodass beim Zugriff über Paradox ein Passwort verlangt wird. Zur Entschlüsselung solcher Tabellen braucht man aber nicht unbedingt das Kennwort: Die Regeln der Verschlüsselung sind fest und der Schlüssel zum Lesen ist in der Datenbank mit gespeichert, sodass keine Brute-Force-Passwortsuche nötig ist. Verschiedene Hilfsprogramme wie decryptpdxtable, pxunsec (bis Version 4) und pxdazz (bis Version 7) können zum Speichern einer unverschlüsselten Kopie bzw. zum Ermitteln des Passwortes einer Paradoxtabelle verwendet werden.[3] Weiterhin existieren einige Universalpasswörter, mit denen jede verschlüsselte Paradoxtabelle geöffnet werden kann.[4]

Weblinks[Bearbeiten | Quelltext bearbeiten]

Einzelnachweise[Bearbeiten | Quelltext bearbeiten]

  1. WordPerfect Office | Free Trial. Abgerufen am 16. November 2019.
  2. WordPerfect Office | Free Trial. Abgerufen am 16. November 2019.
  3. Randybeck.com: Paradox Specification. Abgerufen am 28. Juli 2011.
  4. About.com Delphi Programming: How to open a password protected Paradox DB (if you do not know the password). Abgerufen am 28. Juli 2011 (Archivversion vom 15. Februar 2016).