IDEF1X

aus Wikipedia, der freien Enzyklopädie
Beispielmodell

IDEF1X ist eine Modellierungssprache im Computer-aided-Manufacturing-Standard und gehört zur Gruppe der IDEF-Sprachen. Die 1 steht für die Modellierung von Informationsstrukturen, mit X wird die Erweiterung (engl. Extension) gegenüber dem ursprünglichen Standard gekennzeichnet.

IDEF1X ist eine Datenmodellierungstechnik und fokussiert sich daher auf das Entity-Relationship-Modell (ERM).

Geschichte

Im Rahmen des ICAM-Programms der US Air Force wurde IDEF1 1981 veröffentlicht. Mit den zur gleichen Zeit rasant fortschreitenden Entwicklungen auf dem Gebiet der relationalen Datenbanken musste der Standard relativ schnell erheblich erweitert werden. Diese Erweiterung wurde unter dem Namen IDEF1X erstmals 1985 publiziert. 1994 wurde IDEF1X als U.S.-Behördenstandard übernommen (FIPS 184).

Bedeutung

Wegen der frühen Offenlegung und der gewollten Unabhängigkeit der Modellierungssprache von Herstellern von Datenbank-Software haben viele CASE-Tool-Hersteller die Notation unterstützt. Die Forderung von U.S.-Militär und Behörden machte IDEF1X schließlich zu einem De-facto-Standard (neben anderen).

Umfang

Zu IDEF1X gehört im ursprünglich veröffentlichten Kontext die Datenmodellierung als Methode der Softwareentwicklung mit hinzu. So werden Datenmodellierungskonzepte und Modellierungsrichtlinien mit aufgeführt.

Da diese Themen mittlerweile in der allgemeinen Informatik aufgegangen sind, stehen Syntax und Semantik der Notation bei der Betrachtung von IDEF1X heute im Vordergrund.

Notation

Der Standard legt Notationen für das ER-Diagramm und den zusätzlichen Angaben in der ERM-Dokumentation fest. Im Diagramm gelten zusammengefasst die folgenden Konventionen:

Entity Syntax

Entity-Darstellung

Entities werden als abgerundetes Rechteck dargestellt, wenn sie von einer Beziehung existenzabhängig sind, sonst in einem normalen Rechteck.

Der Name (oder eine Nummer) wird darüber gestellt.

Attribute

Darstellung der Attribute

Die Namen der Attribute werden in das Entity-Rechteck geschrieben. Attribute, die zum Primärschlüssel gehören stehen über, alle anderen unter einem Trennungsstrich.

Zusätzlich zu den Namen werden weitere Kennzeichnungen aufgenommen, z. B. "(O)" für optional.

Beziehungen

[[Hilfe:Cache|Fehler beim Thumbnail-Erstellen]]:
Eltern-Kind Beziehung

Beziehungen kennen (wie z. B. auch in UML) eine Richtung, Sprechweise: Sie gehen vom Eltern-Entity zum Kind-Entity. Das Kind-Ende der Beziehung ist mit einem kleinen schwarzen Kreis gekennzeichnet. Zusätzlich wird durch Linienart, -ende und Kommentierung die Kardinalität der Beziehung dargestellt.

Neben dem Kreis am Kind-Ende der Beziehungslinie steht die Kardinalität der Kind-Entities:

nichts Null, Eins oder beliebig viele
P Eins bis beliebig viele
Z Null oder Eins
n Genau n
n-m zwischen n und m
(i) Verweis auf Notiz i
Datei:IDEF1X Beziehung2.png
Optionale Beziehung

Die Kardinalität der Eltern-Seite der Beziehung kann nur als Kann oder Muss definiert werden. Eine optionale Beziehung wird am Linienende der Elternseite mit einer Raute versehen, eine zwingende Beziehung hat ein normales Linienende.
Dies bedeutet, dass in IDEF1X keine n:m Beziehungen erlaubt sind, die es unter anderem in der Chen-Notation gibt. Eine n:m-Beziehung muss bei der Modellierung in zwei 1:n-Beziehungen aufgebrochen werden.
Eine weitere Besonderheit gegenüber anderen Notationen ist die explizite Darstellung von Fremdschlüssel-Attributen, obwohl diese aus Modellierungssicht redundant sind.

Identifizierende Beziehungen

[[Hilfe:Cache|Fehler beim Thumbnail-Erstellen]]:
Identifizierende Beziehung

Eine identifizierende Beziehung ist eine Eltern-Kind Beziehung, in der das Kind-Entity existenzabhängig vom Eltern-Entity ist und den Primärschlüssel des Eltern-Entities im eigenen Primärschlüssel mit aufnimmt. Diese Beziehungsart wird mit zwei Darstellungserweiterungen modelliert:

  • Die Beziehungslinie ist durchgezogen (eine nicht identifizierende Beziehung ist gestrichelt).
  • Das Kind-Entity wird in einem abgerundeten Rechteck dargestellt, siehe oben.

Sub- und Supertypen

[[Hilfe:Cache|Fehler beim Thumbnail-Erstellen]]:
Supertyp mit Subtypen

Das Konzept der Vererbung, bei der Datenmodellierung als Sub- und Supertyp bezeichnet, wird in IDEF1X über Kategorisierung dargestellt.

Die Kategorisierung ist eine Menge spezieller Beziehungen vom Supertyp zu seinen Subtypen, die mit einem Diskriminator versehen werden. Eine durchgezogene Linie geht vom Supertyp zum Diskriminator, einem Kreis mit einer waagerechten einfachen oder Doppellinie darunter. Von der Diskriminatorlinie aus geht jeweils eine durchgezogene Linie zu jedem Subtyp. Die Doppellinie des Diskriminators steht für die Vollständigkeit der aufgeführten Subtypen, in IDEF1X auch Kategorien genannt.

Weblinks

Commons: IDEF1X – Sammlung von Bildern, Videos und Audiodateien