<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Data_Definition_Language</id>
	<title>Data Definition Language - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Data_Definition_Language"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Data_Definition_Language&amp;action=history"/>
	<updated>2026-05-19T09:44:59Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Wikipedia (Deutsch) – Lokale Kopie</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://wiki-de.moshellshocker.dns64.de/index.php?title=Data_Definition_Language&amp;diff=113891&amp;oldid=prev</id>
		<title>imported&gt;SchlurcherBot: Bot: http → https</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Data_Definition_Language&amp;diff=113891&amp;oldid=prev"/>
		<updated>2026-01-12T02:33:19Z</updated>

		<summary type="html">&lt;p&gt;Bot: http → https&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Die &amp;#039;&amp;#039;&amp;#039;Data Definition Language&amp;#039;&amp;#039;&amp;#039; (&amp;#039;&amp;#039;&amp;#039;DDL&amp;#039;&amp;#039;&amp;#039;; {{deS|Datendefinitionssprache}}&amp;lt;ref&amp;gt;[https://www.geoinformatik.uni-rostock.de/einzel.asp?ID=434 Datendefinitionssprache], Geoinformatik Lexikon, Agrar- und Umweltwissenschaftliche Fakultät – Universität Rostock&amp;lt;/ref&amp;gt;) ist ein Teil einer [[Datenbanksprache]], der verwendet wird, um Datenstrukturen und verwandte Elemente zu beschreiben, zu ändern oder zu entfernen. Ursprünglich bezog sich DDL auf [[Datenbanksystem]]e, der Begriff wird aber heute auch in anderen Zusammenhängen verwendet. Als Datenbanksprache ist DDL die &amp;#039;&amp;#039;Datenbeschreibungssprache&amp;#039;&amp;#039; einer Datenbank.&lt;br /&gt;
&lt;br /&gt;
Es existieren sehr unterschiedliche Ausprägungen der DDL (abhängig vom Verwendungszweck), Beispiele:&lt;br /&gt;
* In den historischen [[Information Management System|IMS]]-Datenbanken werden die Datenstrukturen und deren logische Sichten in Form einer höheren Assemblersprache definiert.&lt;br /&gt;
*: &amp;#039;&amp;#039;Beispiel:&amp;#039;&amp;#039; …&amp;amp;nbsp;&amp;lt;code style=&amp;quot;white-space:nowrap&amp;quot;&amp;gt;SEGM NAME=PROJECT,PARENT=FIRM,BYTES=45 FIELD NAME=(PROJNO,SEQ,U),BYTES=6,START=1&amp;lt;/code&amp;gt;&amp;amp;nbsp;…&lt;br /&gt;
* In [[SQL]] liegt sie (neben [[Data Manipulation Language|DML]] und [[Data Control Language|DCL]]) in Form englischer Befehlsklauseln vor.&lt;br /&gt;
*: &amp;#039;&amp;#039;Beispiel:&amp;#039;&amp;#039; &amp;lt;syntaxhighlight lang=&amp;quot;SQL&amp;quot; style=&amp;quot;white-space:nowrap&amp;quot; inline&amp;gt;CREATE TABLE PROJECT ( PROJNO DECIMAL(6,0) NOT NULL PRIMARY KEY,&amp;lt;/syntaxhighlight&amp;gt;&amp;amp;nbsp;…&lt;br /&gt;
* [[XML Schema]] ist eine DDL zur Beschreibung der Struktur von XML-Dokumenten.&lt;br /&gt;
&lt;br /&gt;
Einige Software-Hersteller weisen auch Berechtigungselemente (z.&amp;amp;nbsp;B. &amp;lt;code&amp;gt;GRANT&amp;lt;/code&amp;gt;) dem DDL-Begriff zu, diese gehören allerdings in der Theorie zur [[Data Control Language]].&lt;br /&gt;
&lt;br /&gt;
Zu &amp;#039;&amp;#039;unterscheiden&amp;#039;&amp;#039; ist eine DDL vom Begriff „[[Deklaration (Programmierung)|Deklaration]]“: Während eine DDL im Allgemeinen zur Festlegung der Struktur von Daten in einem [[Datenbank|DBMS]] dient, wird das Festlegen der Format- und [[Datenstruktur|Strukturangaben]] für hauptspeicher-intern zu verarbeitende Daten –&amp;amp;nbsp;im [[Quelltext]] eines [[Computerprogramm]]s, gemäß der [[Syntax]] einer [[Programmiersprache]]&amp;amp;nbsp;– als „Deklaration“ (zum Teil auch als Definition oder Spezifikation) bezeichnet.&lt;br /&gt;
&lt;br /&gt;
== SQL ==&lt;br /&gt;
In der praktisch wichtigen [[SQL|Structured Query Language]] lautet die Syntax wie folgt:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;SQL&amp;quot;&amp;gt;&lt;br /&gt;
CREATE TABLE Relation ( (Attribut-Definition [PRIMARY KEY])+&lt;br /&gt;
    [, FOREIGN KEY ( Attribut+ ) REFERENCES Relation ( Attribut+ )] )&lt;br /&gt;
DROP TABLE Relation&lt;br /&gt;
ALTER TABLE Relation Alter-Definition&lt;br /&gt;
CREATE INDEX Index-Name ON Relation ( Attribut+ )&lt;br /&gt;
DROP INDEX Index-Name&lt;br /&gt;
CREATE VIEW Sicht [( Attribut+ )] AS SFW-Block [WITH CHECK OPTION]&lt;br /&gt;
DROP VIEW Sicht&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
* &amp;lt;code&amp;gt;PRIMARY KEY&amp;lt;/code&amp;gt; und &amp;lt;code&amp;gt;FOREIGN KEY&amp;lt;/code&amp;gt; sind Teil der SQL-89 IDL bzw. SQL-92 und werden von manchen Datenbanksystemen nicht unterstützt.&lt;br /&gt;
* Die Attribut-Definition enthält den Namen des Attributes, den Datentyp, sowie optionale Angaben wie &amp;lt;code&amp;gt;[[Nullwert|NOT NULL]]&amp;lt;/code&amp;gt;. In SQL-92 können benutzerdefinierte Wertebereiche sowie Defaultwerte angegeben werden.&lt;br /&gt;
* Bei &amp;lt;code&amp;gt;CREATE TABLE&amp;lt;/code&amp;gt; können ab SQL-92 außerdem mittels der &amp;lt;code&amp;gt;CHECK&amp;lt;/code&amp;gt;-Klausel noch Integritätsbedingungen bei den Attributen oder für die Tabelle angegeben werden.&lt;br /&gt;
* Die Alter-Definition ist &amp;lt;code&amp;gt;ADD &amp;#039;&amp;#039;Attribut-Definition&amp;#039;&amp;#039;&amp;lt;/code&amp;gt;. In SQL-92 gibt es noch &amp;lt;code&amp;gt;ALTER &amp;#039;&amp;#039;Attribut&amp;#039;&amp;#039; &amp;#039;&amp;#039;Default-Wert&amp;#039;&amp;#039;&amp;lt;/code&amp;gt; oder &amp;lt;code&amp;gt;DROP &amp;#039;&amp;#039;Attribut&amp;#039;&amp;#039;&amp;lt;/code&amp;gt;. Da SQL-92 sehr restriktiv bezüglich der &amp;lt;code&amp;gt;ALTER&amp;lt;/code&amp;gt;-Anweisung ist, ist dies eine der Anweisungen, die von den Herstellern universell erweitert wurde, so dass beliebige Änderungen möglich sind wie durch eine Folge von &amp;lt;code&amp;gt;DROP&amp;lt;/code&amp;gt; und &amp;lt;code&amp;gt;ADD&amp;lt;/code&amp;gt;-Anweisungen.&lt;br /&gt;
* Bei der Definition einer Sicht können neue Attributnamen vergeben werden. &amp;#039;&amp;#039;SFW-Block&amp;#039;&amp;#039; ist eine beliebige SQL-Abfrage, &amp;lt;code&amp;gt;WITH CHECK OPTION&amp;lt;/code&amp;gt; gibt an, ob gewisse Änderungsoperationen erlaubt sein sollen (vgl. [[Sicht (Datenbank)|Sichten]]). Eine &amp;lt;code&amp;gt;ORDER BY&amp;lt;/code&amp;gt; Klausel ist in Sichtdefinitionen nicht zulässig, da Sichten wieder Relationen sind, und Relationen sind (Multi-)Mengen, also per Definition nicht sortiert.&lt;br /&gt;
* Die &amp;lt;code&amp;gt;CREATE&amp;lt;/code&amp;gt;-Anweisung wird in modernen DBMS dazu benutzt, außer Relationen, Indizes und Sichten alle möglichen anderen Objekte zu kreieren.&lt;br /&gt;
* Der SQL-Standard definiert Indizes überhaupt nicht, so dass die entsprechenden &amp;lt;code&amp;gt;CREATE INDEX&amp;lt;/code&amp;gt; und &amp;lt;code&amp;gt;DROP INDEX&amp;lt;/code&amp;gt; Anweisungen immer produktspezifische Erweiterungen sind. Allerdings verwenden die meisten [[DBMS]] die gleiche oder eine sehr ähnliche Syntax.&lt;br /&gt;
* Mit &amp;lt;code&amp;gt;WITH CHECK OPTION&amp;lt;/code&amp;gt; kann eine [[Sicht (Datenbank)|View]] (virtuelle Tabelle) definiert werden, um somit eine Kontrolle über die Veränderung der Daten zu ermöglichen, welche in einer View dargestellt werden und auch bearbeitet werden können. Durch diese Angabe wird festgelegt, dass Änderungen der View, die den in ihr nicht sichtbaren Teil einer Relation beeinflussen, in einem Test anhand der durch &amp;lt;code&amp;gt;WHERE&amp;lt;/code&amp;gt; angegebenen Parameter erkannt und abgewiesen werden.&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;Beispiele:&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
CREATE TABLE Student (&lt;br /&gt;
   MatrNr INT NOT NULL PRIMARY KEY,&lt;br /&gt;
   Name varchar(50) NOT NULL)&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
: Erzeugt die Tabelle namens &amp;#039;&amp;#039;Student&amp;#039;&amp;#039; mit den Spalten &amp;#039;&amp;#039;MatrNr&amp;#039;&amp;#039; und &amp;#039;&amp;#039;Name&amp;#039;&amp;#039;, wobei &amp;#039;&amp;#039;MatrNr&amp;#039;&amp;#039; der [[Primärschlüssel]] ist und in keiner der Spalten [[Nullwert|leere Felder]] erlaubt sind.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
ALTER TABLE Student ADD Vorname varchar(35)&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
: Definiert eine neue Spalte namens &amp;#039;&amp;#039;Vorname&amp;#039;&amp;#039; in der Tabelle &amp;#039;&amp;#039;Student&amp;#039;&amp;#039;.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
DROP TABLE Student&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
: Löscht die gesamte Tabelle &amp;#039;&amp;#039;Student&amp;#039;&amp;#039;.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
CREATE INDEX idx_Name ON Student (Name)&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
: Legt einen [[Datenbankindex|Index]] auf die Spalte &amp;#039;&amp;#039;Name&amp;#039;&amp;#039; der Tabelle &amp;#039;&amp;#039;Student&amp;#039;&amp;#039;. Der Index bekommt die Bezeichnung &amp;#039;&amp;#039;idx_Name&amp;#039;&amp;#039; und beschleunigt die Suche nach Datensätzen in der Tabelle &amp;#039;&amp;#039;Student&amp;#039;&amp;#039;, wenn der &amp;#039;&amp;#039;Name&amp;#039;&amp;#039; als Suchkriterium angegeben wird.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
DROP index idx_Name&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
: Löscht den Index &amp;#039;&amp;#039;idx_Name&amp;#039;&amp;#039;.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
CREATE VIEW alte_Freunde&lt;br /&gt;
AS SELECT Name, Vorname, Wohnort, Geburtstag&lt;br /&gt;
FROM Freunde&lt;br /&gt;
WHERE Geburtstag &amp;lt;= &amp;#039;1-JAN-1970&amp;#039;&lt;br /&gt;
WITH CHECK OPTION;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
: Zeigt nur Freunde an, die vor dem 1. Januar 1970 geboren wurden und verhindert die Änderung auf Werte größer als der 1. Januar 1970 sowie das Neuanlegen eines Datensatzes mit einem ungültigen Wert.&lt;br /&gt;
&lt;br /&gt;
== Siehe auch ==&lt;br /&gt;
* [[Data Control Language]]&lt;br /&gt;
* [[Data Manipulation Language]]&lt;br /&gt;
* [[Transaction Control Language]]&lt;br /&gt;
&lt;br /&gt;
== Einzelnachweise ==&lt;br /&gt;
&amp;lt;references /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:SQL]]&lt;/div&gt;</summary>
		<author><name>imported&gt;SchlurcherBot</name></author>
	</entry>
</feed>