SQL: Unterschied zwischen den Versionen

Aus Foxwiki
K Textersetzung - „Man-Pages“ durch „Man-Page“
 
(35 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 1: Zeile 1:
'''topic''' kurze Beschreibung
'''topic''' - Kurzbeschreibung
==Beschreibung==
==Beschreibung==
==Installation==
==Anwendungen==
===Fehlerbehebung===
==Syntax==
===Optionen===
===Parameter===
===Umgebungsvariablen===
===Exit-Status===
==Konfiguration==
===Dateien===
==Sicherheit==
==Dokumentation==
===RFC===
===Man-Pages===
===Info-Pages===
==Siehe auch==
==Links==
===Projekt-Homepage===
===Weblinks===
===Einzelnachweise===
<references />
==Testfragen==
<div class="toccolours mw-collapsible mw-collapsed">
''Testfrage 1''
<div class="mw-collapsible-content">'''Antwort1'''</div>
</div>
<div class="toccolours mw-collapsible mw-collapsed">
''Testfrage 2''
<div class="mw-collapsible-content">'''Antwort2'''</div>
</div>
<div class="toccolours mw-collapsible mw-collapsed">
''Testfrage 3''
<div class="mw-collapsible-content">'''Antwort3'''</div>
</div>
<div class="toccolours mw-collapsible mw-collapsed">
''Testfrage 4''
<div class="mw-collapsible-content">'''Antwort4'''</div>
</div>
<div class="toccolours mw-collapsible mw-collapsed">
''Testfrage 5''
<div class="mw-collapsible-content">'''Antwort5'''</div>
</div>
[[Kategorie:Entwurf]]
=Wikipedia=
'''SQL''' (offizielle Aussprache [<nowiki/>{{IPA|ɛskjuːˈɛl}}], mitunter auch [<nowiki/>{{IPA|ˈsiːkwəl}}]; auf Deutsch auch häufig die deutsche Aussprache der Buchstaben) ist eine [[Datenbanksprache]] zur Definition von [[Datenstruktur]]en in [[Relationale Datenbank|relationalen Datenbanken]] sowie zum Bearbeiten (Einfügen, Verändern, Löschen) und Abfragen von darauf basierenden Datenbeständen.
'''SQL''' (offizielle Aussprache [<nowiki/>{{IPA|ɛskjuːˈɛl}}], mitunter auch [<nowiki/>{{IPA|ˈsiːkwəl}}]; auf Deutsch auch häufig die deutsche Aussprache der Buchstaben) ist eine [[Datenbanksprache]] zur Definition von [[Datenstruktur]]en in [[Relationale Datenbank|relationalen Datenbanken]] sowie zum Bearbeiten (Einfügen, Verändern, Löschen) und Abfragen von darauf basierenden Datenbeständen.


Zeile 51: Zeile 6:


Die Bezeichnung ''SQL'' wird im allgemeinen Sprachgebrauch als Abkürzung für „'''Structured Query Language'''“ (auf Deutsch: „Strukturierte Abfrage-Sprache“) aufgefasst, obwohl sie laut Standard ein eigenständiger Name ist. Die Bezeichnung leitet sich von dem Vorgänger SEQUEL ([{{IPA|ˈsiːkwəl}}], Structured English Query Language) ab, welche mit Beteiligung von [[Edgar F. Codd]] (IBM) in den 1970er Jahren von [[Donald D. Chamberlin]] und [[Raymond F. Boyce]] entwickelt wurde. SEQUEL wurde später in SQL umbenannt, weil SEQUEL ein eingetragenes Warenzeichen der [[Hawker Siddeley]] Aircraft Company ist.<ref>[http://www.mcjones.org/System_R/SQL_Reunion_95/sqlr95-System.html ''Diskussion über System R und zur Namensänderung von SEQUEL zu SQL'']</ref>
Die Bezeichnung ''SQL'' wird im allgemeinen Sprachgebrauch als Abkürzung für „'''Structured Query Language'''“ (auf Deutsch: „Strukturierte Abfrage-Sprache“) aufgefasst, obwohl sie laut Standard ein eigenständiger Name ist. Die Bezeichnung leitet sich von dem Vorgänger SEQUEL ([{{IPA|ˈsiːkwəl}}], Structured English Query Language) ab, welche mit Beteiligung von [[Edgar F. Codd]] (IBM) in den 1970er Jahren von [[Donald D. Chamberlin]] und [[Raymond F. Boyce]] entwickelt wurde. SEQUEL wurde später in SQL umbenannt, weil SEQUEL ein eingetragenes Warenzeichen der [[Hawker Siddeley]] Aircraft Company ist.<ref>[http://www.mcjones.org/System_R/SQL_Reunion_95/sqlr95-System.html ''Diskussion über System R und zur Namensänderung von SEQUEL zu SQL'']</ref>
 
==Sprachelemente==
==Sprachelemente und Beispiele==
[[Datei:SQL.png|mini|Bestandteile von SQL]]
[[Datei:SQL.png|mini|Bestandteile von SQL]]


Zeile 67: Zeile 21:
Das Ergebnis einer Abfrage sieht wiederum aus wie eine Tabelle und kann oft auch wie eine Tabelle angezeigt, bearbeitet und weiterverwendet werden. {{Siehe auch|Datenbanktabelle}}
Das Ergebnis einer Abfrage sieht wiederum aus wie eine Tabelle und kann oft auch wie eine Tabelle angezeigt, bearbeitet und weiterverwendet werden. {{Siehe auch|Datenbanktabelle}}


=== Grundlegenden Befehle und Begriffe ===
== Chronologie ==
Die grundlegenden Befehle und Begriffe werden anhand des folgenden Beispiels erklärt:
{| class="wikitable sortable"
 
{|
|- style="border-bottom: 1px solid #EEE;"
![[Entity-Relationship-Modell#ER-Diagramme|ER-Diagramm]]:
| colspan="4" |[[Datei:SQL-Beispiel.svg|700px|SQL-Beispiel]]
|-
|-
!Relationen:
! Jahr !! Beschreibung
|
{| class="wikitable"
|+<code>Student</code>
|'''<u><code>MatrNr</code></u>'''||'''<code>Name</code>'''
|-
|-
|<code>26120</code>||<code>Fichte</code>
| 1975 || ''SEQUEL'' = ''Structured English Query Language'', der Vorläufer von ''SQL'', wird für das Projekt [[System R]] von [[IBM]] entwickelt.
|-
|-
|<code>25403</code>||<code>Jonas</code>
| 1979 || ''SQL'' gelangt mit ''Oracle V2'' erstmals durch ''Relational Software Inc.'' auf den Markt.
|-
|-
|<code>27103</code>||<code>Fauler</code>
| 1986 || ''SQL1'' wird von [[American National Standards Institute|ANSI]] als Standard verabschiedet.
|}
|
{| class="wikitable"
|+<code>hoert</code>
|'''<u><code>MatrNr</code></u>'''||'''<code><u>VorlNr</u></code>'''
|-
|-
|<code>25403</code>||<code>5001</code>
| 1987 || ''SQL1'' wird von der [[Internationale Organisation für Normung|Internationalen Organisation für Normung]] (ISO) als Standard verabschiedet und 1989 nochmals überarbeitet.
|-
|-
|<code>26120</code>||<code>5001</code>
| 1992 || Der Standard ''SQL2'' oder ''SQL-92'' wird von der ISO verabschiedet.
|-
|-
|<code>26120</code>||<code>5045</code>
| 1999 || ''SQL3'' oder ''SQL:1999'' wird verabschiedet. Im Rahmen dieser Überarbeitung werden weitere wichtige Features (wie etwa [[Datenbanktrigger|Trigger]] oder rekursive Abfragen) hinzugefügt.
|}
|
{| class="wikitable"
|+<code>Vorlesung</code>
|'''<u><code>VorlNr</code></u>'''||'''<code>Titel</code>'''||'''<code>PersNr</code>'''
|-
|-
|<code>5001</code>||<code>ET</code>||<code>15</code>
| 2003 || ''SQL:2003''. Als neue Features werden aufgenommen [[SQL/XML]], Window functions, Sequences.
|-
|-
|<code>5022</code>||<code>IT</code>||<code>12</code>
| 2006 ||  ''SQL/XML:2006''. Erweiterungen für [[SQL/XML]]<ref name="SQLXML2006">{{Literatur |Titel=SQL/XML:2006 – Evaluierung der Standardkonformität ausgewählter Datenbanksysteme |Autor=Michael Wagner |Datum=2010 |Verlag=Diplomica Verlag |ISBN=3-8366-9609-6 |Seiten=100}}</ref>.
|-
|-
|<code>5045</code>||<code>DB</code>||<code>12</code>
| 2008 || ''SQL:2008'' bzw. ISO/IEC 9075:2008. Als neue Features werden aufgenommen INSTEAD OF-Trigger, TRUNCATE-Statement und FETCH Klausel.
|}
|
{| class="wikitable"
|+<code>Professor</code>
|'''<u><code>PersNr</code></u>'''||'''<code>Name</code>'''
|-
|-
|<code>12</code>||<code>Wirth</code>
| 2011 || ''SQL:2011'' bzw. ISO/IEC 9075:2011. Als neue Features werden aufgenommen „Zeitbezogene Daten“ (PERIOD FOR). Es gibt Erweiterungen für Window functions und die FETCH Klausel.
|-
|-
|<code>15</code>||<code>Tesla</code>
| 2016 || ''SQL:2016'' bzw. ISO/IEC 9075:2016. Als neue Features werden aufgenommen JSON und „row pattern matching“.
|-
|-
|<code>20</code>||<code>Urlauber</code>
| 2019 || ''SQL/MDA:2019''. Erweiterungen für einen Datentyp „mehrdimensionales Feld“.
|}
|}
|}


===Einfache Abfrage===
==Syntax==
<syntaxhighlight lang="sql">
* [[SQL:Abfragen|Abfragen]]
SELECT *
* [[SQL:Einfügen|Einfügen]]
  FROM Student;
* [[SQL:Ändern|Ändern]]
</syntaxhighlight>
* [[SQL:Löschen|Löschen]]
listet alle Spalten und alle Zeilen der Tabelle <code>Student</code> auf.
* [[SQL:Datendefinition|Datendefinition]]
* [[SQL:Programmierung|Programmierung]]
* [[SQL:Standards|Standards]]


Ergebnis:
==Sicherheit==
{| class="wikitable"
==Dokumentation==
|-
===RFC===
!<code>MatrNr</code>!!<code>Name</code>
===Man-Page===
|-
===Info-Pages===
|<code>26120</code>||<code>Fichte</code>
==Siehe auch==
|-
*[[Data Manipulation Language]]
|<code>25403</code>||<code>Jonas</code>
*[[Data Definition Language]]
|-
*[[Data Control Language]]
|<code>27103</code>||<code>Fauler</code>
*[[Transaction Control Language]]
|}
*[[SQL-Injection]]
*[[SchemaSQL]]
*[[Continuous Query Language]]
*[[Liste der Datenbankmanagementsysteme]]
*[[Bereichsabfrage]]


===Abfrage mit Spaltenauswahl (<code>,</code>)===
==Links==
<syntaxhighlight lang="sql">
===Projekt-Homepage===
SELECT VorlNr,
===Weblinks===
      Titel
  FROM Vorlesung;
</syntaxhighlight>
listet die Spalten <code>VorlNr</code> und <code>Titel</code> aller Zeilen der Tabelle <code>Vorlesung</code> auf.
 
Ergebnis:
{| class="wikitable"
|-
!<code>VorlNr</code>!!<code>Titel</code>
|-
|<code>5001</code>||<code>ET</code>
|-
|<code>5022</code>||<code>IT</code>
|-
|<code>5045</code>||<code>DB</code>
|}
 
===Abfrage mit eindeutigen Werten (<code>DISTINCT</code>)===
<syntaxhighlight lang="sql">
SELECT DISTINCT MatrNr
  FROM hoert;
</syntaxhighlight>
listet nur unterschiedliche Einträge der Spalte <code>MatrNr</code> aus der Tabelle <code>hoert</code> auf. Dies zeigt die Matrikelnummern aller Studenten, die mindestens eine Vorlesung hören, wobei mehrfach auftretende Matrikelnummern nur einmal ausgegeben werden.
 
Ergebnis:
{| class="wikitable"
|-
!<code>MatrNr</code>
|-
|<code>25403</code>
|-
|<code>26120</code>
|}
 
===Abfrage mit Umbenennung (<code>AS</code>)===
<syntaxhighlight lang="sql">
SELECT MatrNr AS Matrikelnummer,
      Name
  FROM Student;
</syntaxhighlight>
listet die Spalten <code>MatrNr</code> und Name aller Zeilen der Tabelle <code>Student</code> auf. <code>MatrNr</code> wird beim Anzeigeergebnis als Matrikelnummer aufgeführt.
 
Ergebnis:
{| class="wikitable"
|-
!<code>Matrikelnummer</code>!!<code>Name</code>
|-
|<code>26120</code>||<code>Fichte</code>
|-
|<code>25403</code>||<code>Jonas</code>
|-
|<code>27103</code>||<code>Fauler</code>
|}
 
==={{Anker|Filter}} Abfrage mit Filter (<code>WHERE</code>)===
<syntaxhighlight lang="sql">
SELECT VorlNr,
      Titel
  FROM Vorlesung
WHERE Titel = 'ET';
</syntaxhighlight>
listet <code>VorlNr</code> und <code>Titel</code> aller derjenigen Zeilen der Tabelle <code>Vorlesung</code> auf, deren Titel <code>ET</code> ist.
 
Die solchermaßen strukturierte, häufig verwendete Anweisung wird nach den Anfangsbuchstaben auch als „SFW-Block“ bezeichnet.
 
Ergebnis:
{| class="wikitable"
|-
!<code>VorlNr</code>!!<code>Titel</code>
|-
|<code>5001</code>||<code>ET</code>
|}
 
===Abfrage mit Filter nach Inhalt (<code>WHERE ... LIKE ...</code>)===
<syntaxhighlight lang="sql">
SELECT Name
  FROM Student
WHERE Name LIKE 'F%';
</syntaxhighlight>
listet die Namen aller Studenten auf, deren Name mit <code>F</code> beginnt (im Beispiel: <code>Fichte</code> und <code>Fauler</code>).
 
<code>LIKE</code> kann mit verschiedenen [[Wildcard (Informatik)|Platzhaltern]] verwendet werden: <code>_</code> steht für ein einzelnes beliebiges Zeichen, <code>%</code> steht für eine beliebige Zeichenfolge. Manche Datenbanksysteme bieten weitere solche ''Wildcard''-Zeichen an, etwa für Zeichenmengen.
 
Ergebnis:
{| class="wikitable"
|-
!<code>Name</code>
|-
|<code>Fichte</code>
|-
|<code>Fauler</code>
|}
 
===Abfrage mit Filter und Sortierung (<code>ORDER BY</code>)===
<syntaxhighlight lang="sql">
  SELECT Vorname,
        Name,
        StrasseNr,
        Plz,
        Ort
    FROM Student
  WHERE Plz = '20095'
ORDER BY Name;
</syntaxhighlight>
listet <code>Vorname</code>, <code>Name</code>, <code>StrasseNr</code>, <code>Plz</code> und <code>Ort</code> aller Studenten aus dem angegebenen Postleitzahlbereich aufsteigend sortiert nach <code>Name</code> auf.
 
==={{Anker|Inner}} Abfrage mit verknüpften Tabellen (<code>,</code> und <code>INNER JOIN</code>)===
<syntaxhighlight lang="sql">
SELECT Vorlesung.VorlNr,
      Vorlesung.Titel,
      Professor.PersNr,
      Professor.Name
  FROM Professor,
      Vorlesung
WHERE Professor.PersNr = Vorlesung.PersNr;
</syntaxhighlight>
 
Die Aufzählung hinter [[From (SQL)|<code>FROM</code>]] legt die Datenquellen fest: an dieser Stelle können mit Hilfe sogenannter [[Join (SQL)|<code>JOIN</code>s]] mehrere Tabellen miteinander verknüpft werden, so dass Daten aus verschiedenen Tabellen zusammengeführt und angezeigt werden.
 
In diesem Beispiel wird ein „innerer natürlicher Verbund“ (<code>NATURAL INNER JOIN</code>) verwendet: Alle Datensätze aus den Tabellen <code>Professor</code> und <code>Vorlesung</code>, die den gleichen Wert im Feld <code>PersNr</code> haben. <code>Professor</code>en ohne <code>Vorlesung</code> und <code>Vorlesung</code>en ohne <code>Professor</code> werden damit nicht angezeigt.
 
Dies ist äquivalent zu:
 
<syntaxhighlight lang="sql">
    SELECT Vorlesung.VorlNr,
          Vorlesung.Titel,
          Professor.PersNr,
          Professor.Name
      FROM Professor
INNER JOIN Vorlesung
        ON Professor.PersNr = Vorlesung.PersNr;
</syntaxhighlight>
 
''Vorsicht: Nicht alle Implementierungen verstehen beide Schreibweisen, die [[Oracle]]-Schreibweise <code>FROM Professor, Vorlesung</code> gilt als veraltet und ist weniger verbreitet. Sie entspricht auch nicht dem ANSI-Standard und sollte deshalb vermieden werden. Aus historischen Gründen ist sie jedoch noch häufig anzutreffen.''
 
Tabellen können nicht nur über Schlüsselfelder, sondern über beliebige Felder miteinander verknüpft werden, wie das folgende, fachlich unsinnige Beispiel zeigt:
 
<syntaxhighlight lang="sql">
SELECT Vorlesung.Titel,
      Professor.Name
  FROM Professor,
      Vorlesung
WHERE Professor.Name <> Vorlesung.Titel
</syntaxhighlight>
 
Das Ergebnis erhält die Kombinationen ''aller'' <code>Professor</code>en und ''aller'' <code>Vorlesung</code>en, wo der Name des <code>Professor</code>s vom Titel der <code>Vorlesung</code> ''abweicht''&nbsp;– das sind einfach alle (keine <code>Vorlesung</code> heißt wie ein <code>Professor</code>):
{| class="wikitable"
|-
!<code>Titel</code>!!<code>Name</code>
|-
|<code>ET</code>||<code>Tesla</code>
|-
|<code>ET</code>||<code>Wirth</code>
|-
|<code>ET</code>||<code>Urlauber</code>
|-
|<code>IT</code>||<code>Tesla</code>
|-
|<code>IT</code>||<code>Wirth</code>
|-
|<code>IT</code>||<code>Urlauber</code>
|-
|<code>DB</code>||<code>Tesla</code>
|-
|<code>DB</code>||<code>Wirth</code>
|-
|<code>DB</code>||<code>Urlauber</code>
|}
 
===Linker äußerer Verbund (<code>LEFT OUTER JOIN</code>)===
<syntaxhighlight lang="sql">
        SELECT Professor.PersNr,
                Professor.Name,
                Vorlesung.VorlNr,
                Vorlesung.Titel
          FROM Professor
LEFT OUTER JOIN Vorlesung
            ON Professor.PersNr = Vorlesung.PersNr;
</syntaxhighlight>
ergibt alle Datensätze der Tabelle <code>Professor</code> verbunden mit den Datensätzen der Tabelle <code>Vorlesung</code>, die den jeweils gleichen Wert im Feld <code>PersNr</code> haben. <code>Professor</code>en ohne Vorlesung sind enthalten, die <code>Vorlesung</code>sspalten im Ergebnis haben dann den Wert <code>NULL</code>. <code>Vorlesung</code>en ohne <code>Professor</code> sind nicht enthalten.
 
Die folgende Abfrage liefert nur diejenigen Datensätze, zu denen kein passender Datensatz im linken äußeren Verbund existiert (alle <code>Professor</code>en, die keine <code>Vorlesung</code>en halten):
 
<syntaxhighlight lang="sql">
        SELECT Professor.PersNr,
                Professor.Name
          FROM Professor
LEFT OUTER JOIN Vorlesung
            ON Professor.PersNr = Vorlesung.PersNr
          WHERE Vorlesung.PersNr IS NULL;
</syntaxhighlight>
 
Das Gleiche kann mittels einer Unterabfrage erreicht werden:
 
<syntaxhighlight lang="sql">
SELECT Professor.PersNr,
      Professor.Name
  FROM Professor
WHERE NOT EXISTS (SELECT *
                    FROM Vorlesung
                    WHERE PersNr = Professor.PersNr);
</syntaxhighlight>
 
===Gruppierung mit Aggregat-Funktionen (<code>GROUP BY</code>)===
<syntaxhighlight lang="sql">
        SELECT Professor.PersNr,
                Professor.Name,
                COUNT(Vorlesung.PersNr) AS Anzahl
          FROM Professor
LEFT OUTER JOIN Vorlesung
            ON Professor.PersNr = Vorlesung.PersNr
      GROUP BY Professor.Name,
                Professor.PersNr;
</syntaxhighlight>
zählt die Anzahl der <code>Vorlesungen</code> pro <code>Professor</code> mit Hilfe der [[Aggregation (Informatik)|Aggregat]]-Funktion <code>COUNT</code>.
 
''Bemerkung'': <code>COUNT(Professor.PersNr)</code> oder <code>COUNT(*)</code> wären falsch ([[Nullwert|<code>NULL</code>-Werte]] sollen nicht mitgezählt werden).
 
===Zusammenfassung eines <code>SELECT</code>===
Zusammengefasst kann man die wichtigsten Elemente einer SQL-<code>SELECT</code>-Abfrage etwa so beschreiben:
 
<syntaxhighlight lang="sql">
SELECT [DISTINCT] Auswahlliste [AS Spaltenalias]
FROM Quelle [ [AS] Tabellenalias], evtl. mit JOIN-Verknüpfungen
[WHERE Where-Klausel]
[GROUP BY ein oder mehrere Group-by-Attribute]
[HAVING Having-Klausel]
[ORDER BY ein oder mehrere Sortierungsattribute mit [ASC|DESC]];
</syntaxhighlight>
'''Erläuterung:'''
 
*'''<code>DISTINCT</code>:''' Gibt an, dass aus der Ergebnisrelation gleiche [[Tupel (Informatik)|Ergebnistupel]] entfernt werden sollen. Es wird also jeder Datensatz nur einmal ausgegeben, auch wenn er mehrfach in der Tabelle vorkommt. Sonst liefert SQL eine [[Multimenge]] zurück.
*'''Auswahlliste:''' Bestimmt, welche Spalten der ''Quelle'' auszugeben sind (<code>*</code> für alle) und ob [[Aggregatfunktion|Aggregatsfunktionen]] anzuwenden sind. Wie bei allen anderen Aufzählungen werden die einzelnen Elemente mit Komma (<code>,</code>) voneinander getrennt.
*'''Quelle:''' Gibt an, wo die Daten herkommen. Es können [[Relation (Datenbank)|Relationen]] und [[Sicht (Datenbank)|Sichten]] angegeben werden und miteinander als [[kartesisches Produkt]] oder als Verbund ([[Relationale Algebra#Join|<code>JOIN</code>]], ab SQL-92) verknüpft werden. Mit der zusätzlichen Angabe eines Namens können Relationen für die Abfrage umbenannt werden (vgl. [[#Sprachelemente und Beispiele|Beispiele]]).
*'''<code>WHERE</code>-Klausel:''' bestimmt Bedingungen, auch Filter genannt, unter denen die Daten ausgegeben werden sollen. In SQL ist hier auch die Angabe von Unterabfragen möglich, so dass SQL ''streng relational vollständig'' wird.
*'''<code>GROUP BY</code>-Attribut:''' Legt fest, ob unterschiedliche Werte als einzelne Zeilen ausgegeben werden sollen (<code>GROUP BY</code> = Gruppierung) oder aber die Feldwerte der Zeilen durch Aggregationen wie Addition (<code>SUM</code>), Durchschnitt (<code>AVG</code>), Minimum (<code>MIN</code>), Maximum (<code>MAX</code>) zu einem Ergebniswert zusammengefasst werden, der sich auf die Gruppierung bezieht.
*'''<code>Having</code>-Klausel:''' Ist wie die <code>WHERE</code>-Klausel, nur dass sich die angegebene Bedingung auf das Ergebnis einer Aggregationsfunktion bezieht, zum Beispiel <code>HAVING SUM (Betrag) > 0</code>.
*'''Sortierungsattribut:''' nach <code>ORDER BY</code> werden Attribute angegeben, nach denen sortiert werden soll. Die Standardvoreinstellung ist <code>ASC</code>, das bedeutet aufsteigende Sortierung, <code>DESC</code> ist absteigende Sortierung.
 
'''Mengenoperatoren''' können auf mehrere <code>SELECT</code>-Abfragen angewandt werden, die gleich viele Attribute haben und bei denen die Datentypen der Attribute übereinstimmen:
 
*'''<code>UNION</code>:''' Vereinigt die Ergebnismengen. In einigen Implementierungen werden mehrfach vorkommende Ergebnistupel wie bei <code>DISTINCT</code> entfernt, ohne dass <code>UNION DISTINCT</code> geschrieben werden muss beziehungsweise darf.
*'''<code>UNION ALL</code>:''' Vereinigt die Ergebnismengen. Mehrfach vorkommende Ergebnistupel bleiben erhalten. Einige Implementierungen interpretieren aber <code>UNION</code> wie <code>UNION ALL</code> und verstehen das <code>ALL</code> möglicherweise nicht und geben eine Fehlermeldung aus.
*'''<code>EXCEPT</code>:''' Liefert die Tupel, die in einer ersten, jedoch nicht in einer zweiten Ergebnismenge enthalten sind. Mehrfach vorkommende Ergebnistupel werden entfernt.
*'''<code>MINUS:</code>''' Ein analoger Operator wie <code>EXCEPT</code>, der von manchen SQL-Dialekten alternativ benutzt wird.
*'''<code>INTERSECT</code>:''' Liefert die Schnittmenge zweier Ergebnismengen. Mehrfach vorkommende Ergebnistupel werden entfernt.
 
===Einfügen von Datensätzen (<code>INSERT INTO ... VALUES ...</code>)===
<syntaxhighlight lang="sql">
INSERT INTO Vorlesung (VorlNr, Titel, PersNr) VALUES (1000, 'Softwareentwicklung 1', 12);
INSERT INTO Vorlesung (VorlNr, Titel, PersNr) VALUES (1600, 'Algorithmen', 12);
INSERT INTO Vorlesung (VorlNr, Titel, PersNr) VALUES (1200, 'Netzwerke 1', 20);
INSERT INTO Vorlesung (VorlNr, Titel, PersNr) VALUES (1001, 'Datenbanken', 15);
</syntaxhighlight>
fügt vier Datensätze in die Tabelle <code>Vorlesung</code> ein. Die Werte müssen mit den Datentypen der Felder <code>VorlNr</code>, <code>Titel</code> und <code>PersNr</code> zusammenpassen.
 
<syntaxhighlight lang="sql">
SELECT *
  FROM Vorlesung;
</syntaxhighlight>
 
liefert dann zum Beispiel das Ergebnis (die Reihenfolge kann auch anders sein):
{| class="wikitable"
|-
!<code>VorlNr</code>!!<code>Titel</code>
!<code>PersNr</code>
|-
|<code>1001</code>
|<code>Datenbanken</code>
|<code>15</code>
|-
|<code>1000</code>
|<code>Softwareentwicklung 1</code>
|<code>12</code>
|-
|<code>1200</code>
|<code>Netzwerke 1</code>
|<code>20</code>
|-
|<code>5001</code>||<code>ET</code>
|<code>12</code>
|-
|<code>5022</code>||<code>IT</code>
|<code>12</code>
|-
|<code>1600</code>
|<code>Algorithmen</code>
|<code>12</code>
|-
|<code>5045</code>||<code>DB</code>
|<code>15</code>
|}
 
===Ändern von Datensätzen (<code>UPDATE</code>)===
<syntaxhighlight lang="sql">
UPDATE Vorlesung
  SET VorlNr = VorlNr + 1000,
      PersNr = 20
WHERE PersNr = 15;
</syntaxhighlight>
ändert alle Datensätze, für die <code>PersNr</code> den Wert <code>15</code> hat. Der Wert von <code>VorlNr</code> wird um <code>1000</code> erhöht und der Wert von <code>PersNr</code> auf <code>20</code> gesetzt.
 
Ergebnis eines nachfolgenden <code>SELECT *</code> ist, eventuell mit anderer Reihenfolge:
{| class="wikitable"
|-
!<code>VorlNr</code>!!<code>Titel</code>
!<code>PersNr</code>
|-
|<code>1000</code>
|<code>Softwareentwicklung 1</code>
|<code>12</code>
|-
|<code>1200</code>
|<code>Netzwerke 1</code>
|<code>20</code>
|-
|<code>1600</code>
|<code>Algorithmen</code>
|<code>12</code>
|-
|<code>2001</code>
|<code>Datenbanken</code>
|<code>20</code>
|-
|<code>5001</code>||<code>ET</code>
|<code>12</code>
|-
|<code>5022</code>||<code>IT</code>
|<code>12</code>
|-
|<code>6045</code>||<code>DB</code>
|<code>20</code>
|}
 
===Löschen von Datensätzen (<code>DELETE</code>)===
<syntaxhighlight lang="sql">
DELETE FROM Vorlesung
WHERE PersNr = 12;
</syntaxhighlight>
löscht alle Datensätze, für die <code>PersNr</code> den Wert <code>12</code> hat.
 
Ergebnis eines nachfolgenden <code>SELECT *</code>, eventuell in anderer Reihenfolge:
{| class="wikitable"
|-
!<code>VorlNr</code>!!<code>Titel</code>
!<code>PersNr</code>
|-
|<code>1200</code>
|<code>Netzwerke 1</code>
|<code>20</code>
|-
|<code>2001</code>
|<code>Datenbanken</code>
|<code>20</code>
|-
|<code>6045</code>||<code>DB</code>
|<code>20</code>
|}
 
===Zusammenfassung von <code>INSERT</code>, <code>UPDATE</code> und <code>DELETE</code>===
Verallgemeinert sehen die Änderungsanweisungen wie folgt aus.
 
<code>INSERT</code>-Anweisung:
<syntaxhighlight lang="sql">
INSERT INTO Quelle [(Auswahlliste)]
VALUES (Werteliste) | SELECT <Auswahlkriterien>;
</syntaxhighlight>
 
<code>UPDATE</code>-Anweisung:
<syntaxhighlight lang="sql">
UPDATE Quelle SET Zuweisungsliste
[FROM From-Klausel]
[WHERE Auswahlbedingung];
</syntaxhighlight>
 
<code>DELETE</code>-Anweisung:
<syntaxhighlight lang="sql">
DELETE FROM Quelle
[WHERE Auswahlbedingung];
</syntaxhighlight>
 
==Datendefinition==
 
===Datenbanktabelle (<code>CREATE TABLE</code>)===
Die [[Datenbanktabelle]] <code>Vorlesung</code> kann mit der folgenden [[Anweisung (Programmierung)|Anweisung]] erzeugt werden:
<syntaxhighlight lang="sql">
CREATE TABLE Vorlesung (VorlNr INT NOT NULL PRIMARY KEY, Titel VARCHAR NOT NULL, PersNr NOT NULL, FOREIGN KEY (PersNr) REFERENCES Professor (PersNr));
</syntaxhighlight>
In keinem der Felder <code>VorlNr</code>, <code>Titel</code>, <code>PersNr</code> ist der Wert <code>NULL</code> erlaubt. Der [[Fremdschlüssel]] <code>PersNr</code> [[Referenz (Programmierung)|referenziert]] den [[Primärschlüssel]] <u><code>PersNr</code></u> der Tabelle <code>Professor</code>. Damit wird sichergestellt, dass in die Tabelle <code>Vorlesung</code> nur [[Datensätze]] eingefügt werden können, für die der Wert von <u><code>PersNr</code></u> in der Tabelle <code>Professor</code> als Primärschlüssel vorkommt (siehe [[SQL#Referenzielle Integrität|referenzielle Integrität]]).
 
===Datenbankindex (<code>CREATE INDEX</code>)===
Mit der [[Anweisung (Programmierung)|Anweisung]]
<syntaxhighlight lang="sql">
CREATE INDEX VorlesungIndex
ON Vorlesung (PersNr, Titel);
</syntaxhighlight>
kann ein [[Datenbankindex]] für die Tabelle <code>Vorlesung</code> definiert werden, der vom Datenbanksystem bei der Ausführung von Abfragen zur Beschleunigung verwendet werden kann. Ob das sinnvoll ist, entscheidet das Datenbanksystem eigenständig durch komplexe Auswertungen und Analysen für jede Abfrage erneut.
 
===Sicht (<code>CREATE VIEW</code>)===
Eine [[Sicht (Datenbank)|Sicht]] ist im Wesentlichen ein Alias für eine [[Datenbankabfrage]]. Sie kann wie eine [[Datenbanktabelle]] verwendet werden. Die [[Anweisung (Programmierung)|Anweisung]]
<syntaxhighlight lang="sql">
    CREATE VIEW Vorlesungssicht AS
    SELECT Vorlesung.VorlNr,
          Vorlesung.Titel,
          Professor.PersNr,
          Professor.Name
      FROM Professor
INNER JOIN Vorlesung
        ON Professor.PersNr = Vorlesung.PersNr;
</syntaxhighlight>
speichert die definierte Abfrage als Sicht. Die Abfrage
<syntaxhighlight lang="sql">
SELECT Titel,
      Name
  FROM Vorlesungssicht
WHERE VorlNr < 5000;
</syntaxhighlight>
verwendet diese [[Sicht (Datenbank)|Sicht]] und könnte zum Beispiel folgendes Ergebnis liefern:
{| class="wikitable"
|-
!<code>Titel</code>
!<code>Name</code>
|-
|<code>Softwareentwicklung 1</code>
|<code>Wirth</code>
|-
|<code>Netzwerke 1</code>
|<code>Urlauber</code>
|-
|<code>Algorithmen</code>
|<code>Wirth</code>
|-
|<code>Datenbanken</code>
|<code>Urlauber</code>
|}
 
===Zusammenfassung von <code>CREATE TABLE</code>, <code>CREATE INDEX</code> und <code>CREATE VIEW</code>===
Zusammengefasst sind die wichtigsten Elemente der Definition einer [[Datenbanktabelle]], eines [[Datenbankindex]] oder einer [[Sicht (Datenbank)|Sicht]] wie folgt anzugeben:
<syntaxhighlight lang="sql">
CREATE TABLE Tabellenname (Attributdefinition [PRIMARY KEY]) [, FOREIGN KEY (Attributliste) REFERENCES Tabellenname (Attributliste)]);
DROP TABLE Tabellenname;
ALTER TABLE Tabellenname (Attributdefinition [PRIMARY KEY]) [, FOREIGN KEY (Attributliste) REFERENCES Tabellenname (Attributliste)]);
 
CREATE INDEX Indexname ON Tabellenname (Attributliste);
DROP INDEX Indexname;
 
CREATE VIEW Sichtname [(Attributliste)] AS SELECT <Auswahlkriterien>;
DROP VIEW Sichtname;
</syntaxhighlight>
 
==Redundanz==
{{Hauptartikel|Normalisierung (Datenbank)}}
 
Ein [[Grundsatz]] des [[Datenbankdesign]]s ist, dass in einer Datenbank keine [[Redundanz (Informationstheorie)|Redundanzen]] auftreten sollen. Dies bedeutet, dass jede Information, also zum Beispiel eine Adresse, nur genau einmal gespeichert wird.
 
:''Beispiel'': in der Teilnehmerliste einer Vorlesung werden die Adressen nicht erneut erfasst, sondern nur indirekt über die Matrikelnummer. Um dennoch eine Teilnehmerliste mit Adressen zu erstellen, erfolgt eine <code>SELECT</code>-Abfrage, in der die Teilnehmertabelle mit der Studententabelle verknüpft wird (siehe oben: <code>JOIN</code>).
 
In manchen Fällen ist die [[Rechenleistung|Performance]] einer Datenbank besser, wenn sie nicht (vollständig) normalisiert wird. In diesem Falle werden in der Praxis oft Redundanzen bewusst in Kauf genommen, um zeitaufwändige und komplexe [[Relationale Algebra#Join|Joins]] zu verkürzen und so die Geschwindigkeit der Abfragen zu erhöhen. Man spricht auch von einer Denormalisierung einer Datenbank. Wann (und ob überhaupt) eine Denormalisierung sinnvoll ist, ist umstritten und hängt von den Umständen ab.
 
==Schlüssel==
{{Hauptartikel|Schlüssel (Datenbank)}}
 
Während die Informationen auf viele Tabellen verteilt werden müssen, um Redundanzen zu vermeiden, sind Schlüssel das Mittel, um diese verstreuten Informationen miteinander zu verknüpfen.
 
So hat in der Regel jeder Datensatz eine eindeutige Nummer oder ein anderes eindeutiges Feld, um ihn zu identifizieren. Diese Identifikationen werden als Schlüssel bezeichnet.
 
Wenn dieser Datensatz in anderen Zusammenhängen benötigt wird, wird lediglich sein Schlüssel angegeben. So werden bei der Erfassung von Vorlesungsteilnehmern nicht deren Namen und Adressen, sondern nur deren jeweilige Matrikelnummer erfasst, aus der sich alle weiteren Personalien ergeben.
 
So kann es sein, dass manche Datensätze nur aus Schlüsseln (meist Zahlen) bestehen, die erst in Verbindung mit Verknüpfungen verständlich werden. Der eigene Schlüssel des Datensatzes wird dabei als Primärschlüssel bezeichnet. Andere Schlüssel im Datensatz, die auf die Primärschlüssel anderer Tabellen verweisen, werden als Fremdschlüssel bezeichnet.
 
Schlüssel können auch aus einer Kombination mehrerer Angaben bestehen. Zum Beispiel können die Teilnehmer einer Vorlesung durch die eindeutige Kombination von Vorlesungsnummer und Studentennummer identifiziert werden, so dass die doppelte Anmeldung eines Studenten zu einer Vorlesung ausgeschlossen ist.
 
==Referenzielle Integrität==
{{Hauptartikel|Referentielle Integrität}}
 
Referenzielle Integrität bedeutet, dass Datensätze, die von anderen Datensätzen verwendet werden, in der Datenbank auch vollständig vorhanden sind.
 
:Im obigen Beispiel bedeutet dies, dass in der Teilnehmertabelle nur Matrikel-Nummern gespeichert sind, die es in der Studenten-Tabelle auch tatsächlich gibt.
 
Diese wichtige Funktionalität kann (und sollte) bereits von der Datenbank überwacht werden, so dass zum Beispiel
*nur vorhandene Matrikelnummern in die Teilnehmertabelle eingetragen werden können,
*der Versuch, den Datensatz eines Studenten, der schon eine Vorlesung belegt hat, zu ''löschen'', entweder verhindert wird (Fehlermeldung) oder der Datensatz auch gleich aus der Teilnehmertabelle entfernt wird (Löschweitergabe) und
*der Versuch, die Matrikelnummer eines Studenten, der schon eine Vorlesung belegt hat, zu ''ändern'', entweder verhindert wird (Fehlermeldung) oder der Eintrag in der Teilnehmertabelle gleich mitgeändert wird (Aktualisierungsweitergabe).
 
Widersprüchlichkeit von Daten wird allgemein als [[Konsistenz (Datenspeicherung)#Konsistenz in klassischen relationalen Datenbanken|Dateninkonsistenz]] bezeichnet. Diese besteht, wenn Daten bspw. die [[Integritätsbedingung]]en (z.&nbsp;B. [[Constraint]]s oder [[Schlüssel (Datenbank)#Fremdschlüssel|Fremdschlüsselbeziehungen]]) nicht erfüllen.
 
Ursachen für Dateninkonsistenzen können Fehler bei der Analyse des Datenmodells, fehlende [[Normalisierung (Datenbank)|Normalisierung]] des [[Entity-Relationship-Modell|ERM]] oder Fehler in der Programmierung sein.
 
Zum letzteren gehören die ''[[Verlorene Updates|Lost-Update]]''-Phänomene sowie die Verarbeitung von zwischenzeitlich veralteten Zwischenergebnissen. Dies tritt vor allem bei der Online-Verarbeitung auf, da dem Nutzer angezeigte Werte nicht in einer Transaktion gekapselt werden können.
 
Beispiel:
Transaktion ''A'' liest Wert ''x''
Transaktion ''B'' verringert Wert ''x'' um 10
Transaktion ''A'' erhöht den gespeicherten Wert von ''x'' um eins und schreibt zurück
Ergebnis x' = x+1
Die Änderung von ''B'' ist verloren gegangen
 
==SQL-Datentypen==
{{Hauptartikel|Datentypen}}
 
In den oben vorgestellten Befehlen
<code>create table</code> und <code>alter
table</code> wird bei der Definition jeder Spalte angegeben,
welchen [[Datentyp]] die Werte dieser Spalte annehmen können. Dazu
liefert SQL eine ganze Reihe standardisierter Datentypen mit. Die
einzelnen DBMS-Hersteller haben diese Liste jedoch um eine Unzahl
weiterer Datentypen erweitert. Die wichtigsten Standarddatentypen sind:
 
;<code>integer</code>
:[[Ganze Zahl]] (positiv oder negativ), wobei je nach Zahl der verwendeten Bits Bezeichnungen wie ''smallint'', ''tinyint'' oder ''bigint'' verwendet werden. Die jeweiligen Grenzen und die verwendete Terminologie sind vom Datenbanksystem definiert.
;<code>numeric (n, m)</code> oder <code>decimal (n, m)</code>
:[[Festkommazahl]] (positiv oder negativ) mit insgesamt maximal <code>n</code> Stellen, davon <code>m</code> Nachkommastellen. Wegen der hier erfolgenden Speicherung als Dezimalzahl ist eine besonders für Geldbeträge notwendige Genauigkeit gegeben.
;<code>float (m)</code>
:[[Gleitkommazahl]] (positiv oder negativ) mit maximal <code>m</code> Nachkommastellen.
;<code>real</code>
:[[Gleitkommazahl]] (positiv oder negativ). Die Genauigkeit für diesen Datentyp ist jeweils vom Datenbanksystem definiert.
;<code>double</code> oder <code>double precision</code>
:[[Gleitkommazahl]] (positiv oder negativ). Die Genauigkeit für diesen Datentyp ist jeweils vom Datenbanksystem definiert.
;<code>float</code> und <code>double</code>
:sind für technisch-wissenschaftliche Werte geeignet und umfassen auch die Exponentialdarstellung. Wegen der Speicherung im Binärformat sind sie aber für Geldbeträge nicht geeignet, weil sich beispielsweise der Wert 0,10&nbsp;€ (entspricht 10 Cent) nicht exakt abbilden lässt.
;<code>character (n)</code> oder <code>char (n)</code>
:[[Zeichenkette]] Text mit <code>n</code> Zeichen.
;<code>varchar (n)</code> oder <code>character varying (n)</code>
:Zeichenkette (also Text) von variabler Länge, aber maximal <code>n</code> druckbaren und/oder nicht druckbaren Zeichen. Die Variante <code>varchar2</code> ist für [[Oracle (Datenbanksystem)|Oracle]] spezifisch, ohne dass sie sich tatsächlich unterscheidet.
;<code>text</code>
:Zeichenkette (zumindest theoretisch) beliebiger Länge. In manchen Systemen synonym zu <code>clob</code>.
;<code>date</code>
:Datum (ohne Zeitangabe)
;<code>time</code>
:Zeitangabe (evtl. inklusive Zeitzone)
;<code>timestamp</code>
:Zeitstempel (umfasst Datum und Uhrzeit; evtl. inklusive Zeitzone), meistens mit Millisekundenauflösung, teilweise auch mikrosekundengenau
;<code>boolean</code>
:[[Boolesche Variable]] (kann die Werte <code>true</code>(wahr) oder <code>false</code> (falsch) oder <code>NULL</code> (unbekannt) annehmen). Dieser Datentyp ist laut SQL:2003 optional und nicht alle DBMS stellen diesen Datentyp bereit.
;<code>[[Binary Large Object|blob]] (n)</code> oder <code>binary large object (n)</code>
:Binärdaten von maximal <code>n</code> [[Byte]]s Länge.
;<code>[[Character Large Object|clob]] (n)</code> oder <code>character large object (n)</code>
:Zeichenketten mit maximal <code>n</code> Zeichen Länge.
 
Wenn es die Tabellendefinition erlaubt, können Attribute auch den Wert
<code>NULL</code> annehmen, wenn kein Wert bekannt ist oder aus anderen Gründen kein Wert gespeichert werden soll. Der
<code>NULL</code>-Wert ist von allen anderen möglichen Werten des Datentyps verschieden.
 
==Transaktion, Commit und Rollback==
{{Hauptartikel|Transaktion (Informatik)}}
 
Eine Transaktion bezeichnet eine Menge von Datenbankänderungen, die zusammen ausgeführt werden (müssen). So ist beispielsweise die Buchung (als Transaktion) eines Geldbetrags durch zwei atomare Datenbankoperationen „Abbuchen des Geldbetrages von Konto A“ und „Buchung des Geldbetrages auf Konto B“ gekennzeichnet. Kann die vollständige Abarbeitung der elementaren Datenbankoperationen der Transaktion nicht durchgeführt werden (z.&nbsp;B. aufgrund eines Fehlers), müssen alle durchgeführten Änderungen an dem Datenbestand auf den Ausgangszustand zurückgesetzt werden.
 
Der Vorgang, der alle Änderungen einer Transaktion zurücksetzt, wird als Rollback bezeichnet. Der Begriff Commit bezeichnet das Ausführen einer Transaktion. Transaktionen sind eine Möglichkeit, die Konsistenz des Datenbestandes zu sichern. Im Beispiel der doppelten Kontenführung wird durch das Verhindern von ungültigen Teilbuchungen eine ausgeglichene Kontobilanz gewährleistet.
 
Datenbanken erlauben es zum Teil, bestimmte Befehle außerhalb einer Transaktion auszuführen. Darunter fällt insbesondere das Laden von Daten in Tabellen oder das Exportieren von Daten mittels Utilities. Manche [[DBMS]] erlauben das temporäre Abschalten der Transaktionslogik sowie einiger Kontrollen zur Erhöhung der Verarbeitungsgeschwindigkeit. Dies muss allerdings meist durch einen expliziten Befehl erzwungen werden, um ein versehentliches Ändern von Daten außerhalb einer Transaktion zu vermeiden. Solche Änderungen können, falls eine Datenbankwiederherstellung erforderlich ist, zu schweren Problemen oder gar Datenverlusten führen.
Eine Transaktion wird mit der SQL-Anweisung <code>[[Commit]]</code> beendet. Alle Änderungen der Transaktion werden [[Persistenz (Informatik)|persistent]] gemacht, und das DBMS stellt durch geeignete (interne) Mittel (z.&nbsp;B. Logging) sicher, dass diese Änderungen nicht verloren gehen.
 
Mit dem Befehl <code>[[Rollback]]</code> wird eine Transaktion ebenfalls beendet, es werden jedoch alle Änderungen seit Beginn der Transaktion rückgängig gemacht. Das heißt, der Zustand des Systems (in Bezug auf die Änderungen der Transaktion) ist der gleiche wie vor der Transaktion.
 
==Programmieren mit SQL==
===Programmierschnittstelle===
Das ursprüngliche SQL war keine [[Turing-Vollständigkeit|Turing-vollständige]] [[Programmiersprache]], es ermöglichte also nicht die Realisierung von beliebigen [[Computerprogramm]]en. Mittlerweile lässt es sich mit anderen Programmiersprachen kombinieren, um eine [[Programmierung]] im engeren Sinne zu ermöglichen. Hierfür gibt es unterschiedliche Techniken.
 
*Mit [[Embedded SQL]] können SQL-Anweisungen im Quelltext eines Programms, typischerweise in [[C (Programmiersprache)|C]], [[C++]], [[COBOL]], [[Ada (Programmiersprache)|Ada]], [[Pascal (Programmiersprache)|Pascal]] o.&nbsp;Ä. geschrieben, eingebettet werden. Während der Programmvorbereitung übersetzt ein [[Precompiler]] die SQL-Befehle in Funktionsaufrufe. Embedded SQL ist Teil des ANSI-SQL-Standards. Beispiele für Implementierungen: [[SQLJ]] für [[Java (Programmiersprache)|Java]], [[Pro*C]] für [[C (Programmiersprache)|C]], C++, [[ActiveX Data Objects|ADO]] und [[ADO.NET]].
*Herkömmliche ''[[Programmierschnittstelle]]n'' erlauben die direkte Übergabe von SQL-Befehlen an Datenbanksysteme über Funktionsaufrufe. Beispiele: [[ODBC]], [[Java Database Connectivity|JDBC]], [[ActiveX Data Objects|ADO]].
*[[Persistenz (Informatik)|Persistenz]]-[[Framework]]s wie etwa [[Hibernate (Framework)|Hibernate]] oder [[iBATIS]] abstrahieren vom Datenbankzugriff und ermöglichen [[Objektorientierte Programmierung|objektorientierte]] Verarbeitung von relationalen Datenbanken in einer objektorientierten Programmiersprache (z.&nbsp;B. [[Java (Programmiersprache)|Java]] oder [[C-Sharp|C#]])
*Mit dem Teil 4 ''SQL/PSM'' des Standards werden Konstrukte wie IF-Blöcke und Schleifen bereitgestellt. Er wird in den Datenbanksystemen in unterschiedlicher Ausprägung und mit Hersteller-spezifischen Erweiterungen implementiert, z.&nbsp;B. [[PL/SQL]] in [[Oracle (Datenbanksystem)|Oracle]] oder [[Transact-SQL]] im [[Microsoft SQL Server|MS SQL Server]].
 
===Statisches und dynamisches SQL===
Unabhängig von der verwendeten Programmiertechnik wird zwischen ''statischem'' und ''dynamischem'' SQL unterschieden.
 
*Bei ''statischem SQL'' ist die SQL-Anweisung dem Datenbanksystem zum Zeitpunkt der Programmübersetzung bekannt und festgelegt (z.&nbsp;B. wenn die Abfrage eines Kontos vorformuliert ist und zur Laufzeit nur die Kontonummer eingesetzt wird).
*Bei ''dynamischem SQL'' ist die SQL-Anweisung dem Datenbanksystem erst zum Zeitpunkt der Programmausführung bekannt (z.&nbsp;B. weil der Benutzer die komplette Abfrage eingibt). So sind z.&nbsp;B. alle SQL-Anweisungen, die mittels [[SQL/CLI]] oder [[JDBC]] ausgeführt werden grundsätzlich dynamisch. Ausgeführt werden dynamische SQL-Anweisungen im Allgemeinen mit execute immediate (''SQL-String'').
 
Bei dynamischem SQL ''muss'' das Datenbanksystem die SQL-Anweisung zur Laufzeit des Programms interpretieren und den Zugriffspfad optimieren. Da dieser sogenannte Parse-Vorgang Zeit in Anspruch nimmt, puffern viele Datenbanksysteme die bereits geparsten SQL-Anweisungen, um mehrfaches Parsen gleicher Abfragen zu vermeiden.
Bei statischem SQL ''kann'' schon bei der Übersetzung der Programme bzw. beim Binden der SQL-Anweisungen an eine Datenbank (sogenanntes ''Bind'' der SQL-Befehle) der optimale Zugriffsweg bestimmt werden. Damit sind kürzestmögliche Laufzeiten der Anwendungsprogramme möglich, allerdings muss der Zugriffsweg aller betroffenen Programme neu bestimmt werden, wenn sich Voraussetzungen (z.&nbsp;B. Statistiken) ändern (''Rebind''). Die ''Bind''-Phase ist heute vor allem im [[Großrechner]]-Umfeld bekannt, die meisten Datenbanksysteme optimieren hingegen zur Laufzeit.
 
==Chronologie==
*etwa 1975: ''SEQUEL'' = ''Structured English Query Language'', der Vorläufer von ''SQL'', wird für das Projekt [[System R]] von [[IBM]] entwickelt.
*1979: ''SQL'' gelangt mit ''Oracle V2'' erstmals durch ''Relational Software Inc.'' auf den Markt.
*1986: ''SQL1'' wird von [[American National Standards Institute|ANSI]] als Standard verabschiedet.
*1987: ''SQL1'' wird von der [[Internationale Organisation für Normung|Internationalen Organisation für Normung]] (ISO) als Standard verabschiedet und 1989 nochmals überarbeitet.
*1992: Der Standard ''SQL2'' oder ''SQL-92'' wird von der ISO verabschiedet.
*1999: ''SQL3'' oder ''SQL:1999'' wird verabschiedet. Im Rahmen dieser Überarbeitung werden weitere wichtige Features (wie etwa [[Datenbanktrigger|Trigger]] oder rekursive Abfragen) hinzugefügt.
*2003: ''SQL:2003''. Als neue Features werden aufgenommen [[SQL/XML]], Window functions, Sequences.
*2006: ''SQL/XML:2006''. Erweiterungen für [[SQL/XML]]<ref name="SQLXML2006">{{Literatur |Titel=SQL/XML:2006 – Evaluierung der Standardkonformität ausgewählter Datenbanksysteme |Autor=Michael Wagner |Datum=2010 |Verlag=Diplomica Verlag |ISBN=3-8366-9609-6 |Seiten=100}}</ref>.
*2008: ''SQL:2008'' bzw. ISO/IEC 9075:2008. Als neue Features werden aufgenommen INSTEAD OF-Trigger, TRUNCATE-Statement und FETCH Klausel.
*2011: ''SQL:2011'' bzw. ISO/IEC 9075:2011. Als neue Features werden aufgenommen „Zeitbezogene Daten“ (PERIOD FOR). Es gibt Erweiterungen für Window functions und die FETCH Klausel.
*2016: ''SQL:2016'' bzw. ISO/IEC 9075:2016. Als neue Features werden aufgenommen JSON und „row pattern matching“.
*2019: ''SQL/MDA:2019''. Erweiterungen für einen Datentyp „mehrdimensionales Feld“.
 
==Sprachstandard==
Ziel der Standardisierung ist es, [[Anwendungsprogramm]]e so erstellen zu können, dass sie vom verwendeten Datenbanksystem unabhängig sind. Heutige Datenbanksysteme [[Implementierung|implementieren]] mehr oder weniger große Teile des Sprachstandards. Darüber hinaus stellen sie oftmals herstellerspezifische Erweiterungen bereit, die nicht dem Standard-Sprachumfang entsprechen. In der Vor-SQL-Zeit strebte man die Portabilität von Anwendungen über die [[Kompatible Schnittstellen|kompatible Schnittstelle]] an.
 
Der Standard besteht insgesamt aus zehn einzelnen Publikationen:<ref>{{Internetquelle |url=https://www.iso.org/committee/45342/x/catalogue/p/1/u/0/w/0/d/0 |hrsg=International Organization for Standardization |titel=ISO/IEC 9075 und 13249 |sprache=en |zugriff=2018-09-20}}</ref>
*ISO/IEC 9075-1:2016 Part 1: Framework (SQL/Framework)
*ISO/IEC 9075-2:2016 Part 2: Foundation (SQL/Foundation)
*ISO/IEC 9075-3:2016 Part 3: Call-Level Interface (SQL/CLI)
*ISO/IEC 9075-4:2016 Part 4: Persistent stored modules (SQL/PSM)
*ISO/IEC 9075-9:2016 Part 9: Management of External Data (SQL/MED)
*ISO/IEC 9075-10:2016 Part 10: Object language bindings ([[SQLJ|SQL/OLB]])
*ISO/IEC 9075-11:2016 Part 11: Information and definition schemas (SQL/Schemata)
*ISO/IEC 9075-13:2016 Part 13: SQL Routines and types using the Java TM programming language ([[SQLJ|SQL/JRT]])
*ISO/IEC 9075-14:2016 Part 14: XML-Related Specifications ([[SQL/XML]])
*ISO/IEC 9075-15:2019 Part 15: Multi-dimensional arrays (SQL/MDA)
Ein weiterer Teil befindet sich derzeit (2019) in Entwicklung:
*ISO/IEC 9075-16:20xx Part 16: Property Graph Queries (SQL/PGQ)
 
Der Standard wird durch sechs, ebenfalls standardisierte ''SQL multimedia and application packages'' ergänzt:
*ISO/IEC 13249-1:2016 Part 1: Framework
*ISO/IEC 13249-2:2003 Part 2: Full-Text
*ISO/IEC 13249-3:2016 Part 3: Spatial
*ISO/IEC 13249-5:2003 Part 5: Still image
*ISO/IEC 13249-6:2006 Part 6: Data mining
*ISO/IEC 13249-7:2013 Part 7: History
 
Weiterhin existieren eine Reihe Technical Reports, die eine Einführung zu den einzelnen Themen bieten.
 
*ISO/IEC TR 19075-1:2011 Part 1: XQuery Regular Expression Support in SQL [https://standards.iso.org/ittf/PubliclyAvailableStandards/c041528_ISO_IEC_TR_19075-1_2011.zip Download]
*ISO/IEC TR 19075-2:2015 Part 2: SQL Support for Time-Related Information [https://standards.iso.org/ittf/PubliclyAvailableStandards/c060394_ISO_IEC_TR_19075-2_2015.zip Download]
*ISO/IEC TR 19075-3:2015 Part 3: SQL Embedded in Programs using the JavaTM programming language [https://standards.iso.org/ittf/PubliclyAvailableStandards/c065141_ISO_IEC_TR_19075-3_2015.zip Download]
*ISO/IEC TR 19075-4:2015 Part 4: SQL with Routines and types using the JavaTM programming language [https://standards.iso.org/ittf/PubliclyAvailableStandards/c065142_ISO_IEC_TR_19075-4_2015.zip Download]
*ISO/IEC TR 19075-5:2016 Part 5: Row Pattern Recognition in SQL [https://standards.iso.org/ittf/PubliclyAvailableStandards/c065143_ISO_IEC_TR_19075-5_2016.zip Download]
*ISO/IEC TR 19075-6:2017 Part 6: SQL support for JavaScript Object Notation (JSON) [https://standards.iso.org/ittf/PubliclyAvailableStandards/c067367_ISO_IEC_TR_19075-6_2017.zip Download]
*ISO/IEC TR 19075-7:2017 Part 7: Polymorphic table functions in SQL [https://standards.iso.org/ittf/PubliclyAvailableStandards/c069776_ISO_IEC_TR_19075-7_2017.zip Download]
*ISO/IEC TR 19075-8:2019 Part 8: Multi-dimensional arrays (SQL/MDA)  (wurde zurückgezogen<ref>{{Internetquelle |autor=14:00-17:00 |url=https://www.iso.org/cms/render/live/en/sites/isoorg/contents/data/standard/06/97/69777.html |titel=ISO/IEC TR 19075-8:2019 |sprache=en |abruf=2022-08-24}}</ref>)
Ein weiterer Teil befindet sich derzeit (2019) in Entwicklung:
*ISO/IEC TR 19075-9:20xx Part 9: Online Analytic Processing (OLAP) capabilities
 
Der offizielle Standard ist nicht frei verfügbar, jedoch existiert ein Zip-Archiv mit einer Arbeitsversion von 2008.<ref>[http://www.wiscorp.com/sql200n.zip Arbeitsversion des Standards von 2008] ([[ZIP-Dateiformat|ZIP]]; 12,7&nbsp;MB)</ref> Die Technical Reports sind kostenlos von ISO erhältlich.
 
==Erweiterungen==
Die beiden ersten Teile des SQL Standards ''SQL/Framework'' und ''SQL/Foundation'' legen die Kernfunktionalitäten fest. In den weiteren Teilen werden spezifische Aspekte der Sprache definiert.
 
*Teil 4: Bei ''SQL/PSM'' handelt es sich um die Erweiterung um prozedurale Konstrukte. Sie ermöglichen unter anderem das Programmieren von Schleifen (FOR, WHILE, REPEAT UNTIL, LOOP), Cursorn, Exception-Handling, Triggern und eigenen Funktionen. Oracle implementiert diese Funktionalität unter dem Namen ''[[PL/SQL]]'', DB2 verwendet den Begriff ''[[SQL/PL]]'', PostgreSQL nennt es ''[[PL/pgSQL]]''.
*Teil 14: ''[[SQL/XML]]'' ermöglicht es, [[Extensible Markup Language|XML]]-Dokumente in SQL-Datenbanken zu speichern, mit [[XPath]] in SQL/XML:2003 und [[XQuery]] ab SQL/XML:2006 abzufragen und relationale Datenbankinhalte als XML zu exportieren. Um die ursprünglichen Arbeiten an diesem Teil des Standards zu beschleunigen, hatte sich im Jahr 2000 eine informelle Arbeitsgruppe gebildet (IBM, Oracle, …), die unter dem Namen ''The SQLX Group'' und unter der Bezeichnung ''SQLX'' die Kernfunktionalitäten festlegte. Deren Arbeit ist in den jetzigen Standard eingeflossen.
 
Als Ergänzung zum SQL-Standard existiert mit ''ISO/IEC 13249: SQL multimedia and application packages'' eine Norm, die für die Anwendungsfälle ''Text'', ''Geografische Daten'', ''Bilder'', ''Data mining'' und ''Metadaten'' spezialisierte Schnittstellen in SQL Syntax festlegt.
 
==Literatur==
*Donald D. Chamberlin, Raymond F. Boyce: ''SEQUEL: A Structured English Query Language''. In: ''SIGMOD Workshop.'' Vol. 1 1974, S. 249–264.
*Donald D. Chamberlin, Morton M. Astrahan, Kapali P. Eswaran, Patricia P. Griffiths, Raymond A. Lorie, James W. Mehl, Phyllis Reisner, Bradford W. Wade: ''SEQUEL 2: A Unified Approach to Data Definition, Manipulation, and Control''. In: ''IBM Journal of Research and Development.'' 20(6) 1976, S. 560–575.
*Günter Matthiessen, Michael Unterstein: ''Relationale Datenbanken und SQL in Theorie und Praxis'' Springer Vieweg, [[index.php?title=Special:BookSources/9783642289859|ISBN 978-3-642-28985-9]].
*Edwin Schicker: ''Datenbanken und SQL – Eine praxisorientierte Einführung.'' Teubner, [[index.php?title=Special:BookSources/351902991X|ISBN 3-519-02991-X]].
*Oliver Bartosch, Markus Throll: ''Einstieg in SQL.'' Galileo Press, [[index.php?title=Special:BookSources/3898424979|ISBN 3-89842-497-9]].
*Daniel Warner, Günter Leitenbauer: ''SQL.'' Franzis, [[index.php?title=Special:BookSources/3772375278|ISBN 3-7723-7527-8]].
*H. Faeskorn-Woyke, B. Bertelsmeier, P. Riemer, E. Bauer: ''Datenbanksysteme, Theorie und Praxis mit SQL2003, Oracle und MySQL.'' Pearson-Studium, [[index.php?title=Special:BookSources/9783827372666|ISBN 978-3-8273-7266-6]].
*Jörg Fritze, Jürgen Marsch: ''Erfolgreiche Datenbankanwendung mit SQL3. Praxisorientierte Anleitung – effizienter Einsatz – inklusive SQL-Tuning.'' Vieweg Verlag, [[index.php?title=Special:BookSources/3528552107|ISBN 3-528-55210-7]].
*Can Türker: ''SQL 1999 & SQL 2003.'' Dpunkt Verlag, [[index.php?title=Special:BookSources/3898642194|ISBN 3-89864-219-4]].
*Gregor Kuhlmann, Friedrich Müllmerstadt: ''SQL.'' Rowohlt, [[index.php?title=Special:BookSources/3499612453|ISBN 3-499-61245-3]].
*Michael J. Hernandez, John L. Viescas: ''Go To SQL.'' Addison-Wesley, [[index.php?title=Special:BookSources/382731772X|ISBN 3-8273-1772-X]].
*[[Alfons Kemper|A. Kemper]], A. Eickler: ''Datenbanksysteme – Eine Einführung.'' Oldenbourg, [[index.php?title=Special:BookSources/3486250531|ISBN 3-486-25053-1]].
*Marcus Throll, Oliver Bartosch: ''Einstieg in SQL 2008.'' 2. Auflage. Galileo Computing, [[index.php?title=Special:BookSources/9783836210393|ISBN 978-3-8362-1039-3]] inklusive Übungssoftware SQL-Teacher
*Marco Skulschus: ''SQL und relationale Datenbanken'' Comelio Medien, [[index.php?title=Special:BookSources/9783939701118|ISBN 978-3-939701-11-8]].
*Michael Wagner: ''SQL/XML:2006 – Evaluierung der Standardkonformität ausgewählter Datenbanksysteme'' 1. Auflage. Diplomica Verlag, [[index.php?title=Special:BookSources/3836696096|ISBN 3-8366-9609-6]].
*Christian F. G. Schendera: ''SQL mit SAS. Band 1: PROC SQL für Einsteiger''. Oldenbourg Wissenschaftsverlag, München 2011, [[index.php?title=Special:BookSources/9783486598407|ISBN 978-3-486-59840-7]].
*Christian F. G. Schendera: ''SQL mit SAS. Band 2: Fortgeschrittenes PROC SQL''. Oldenbourg Wissenschaftsverlag, München 2012, [[index.php?title=Special:BookSources/9783486598360|ISBN 978-3-486-59836-0]].
*[[Christopher J. Date|C. J. Date]] with [[Hugh Darwen]]: ''A Guide to the SQL standard: a users guide to the standard database language SQL, 4th ed.'', Addison-Wesley, USA 1997, [[index.php?title=Special:BookSources/9780201964264|ISBN 978-0-201-96426-4]]
*Jim Melton: ''Advanced SQL:1999: Understanding Object-Relational and Other Advanced Features, 1st ed.'', Morgan Kaufmann, USA, 2002, [[index.php?title=Special:BookSources/9781558606777|ISBN 978-1558606777]].
 
==Weblinks==
{{Wikibooks|Einführung in SQL|SQL}}
{{Wikibooks|Einführung in SQL|SQL}}
*[https://www.youtube.com/playlist?list=PLC4UZxBVGKte0o6iUssqQVmXhryrOqPXi Erklärvideos zu SQL], Big Data Analytics Group, Uni Saarland
*[https://www.youtube.com/playlist?list=PLC4UZxBVGKte0o6iUssqQVmXhryrOqPXi Erklärvideos zu SQL], Big Data Analytics Group, Uni Saarland
Zeile 807: Zeile 85:
*[https://esb-dev.github.io/mat/sql-merkblatt.pdf Merkblatt SQL]
*[https://esb-dev.github.io/mat/sql-merkblatt.pdf Merkblatt SQL]
*[http://www.mcjones.org/System_R/SQL_Reunion_95/ The 1995 SQL Reunion: People, Projects, and Politics] – zur frühen Geschichte von SQL (englisch)
*[http://www.mcjones.org/System_R/SQL_Reunion_95/ The 1995 SQL Reunion: People, Projects, and Politics] – zur frühen Geschichte von SQL (englisch)
*[http://www.wiscorp.com/SQLStandards.html Frei verfügbare SQL-Standard-Dokumente], z.&nbsp;B. SQL:2003 und SQL:2008 (englisch)
*[http://www.wiscorp.com/SQLStandards.html Frei verfügbare SQL-Standard-Dokumente], z.&nbsp;B.&nbsp;SQL:2003 und SQL:2008 (englisch)
*[http://www.1keydata.com/de/sql/ SQL-Tutorial]
*[http://www.1keydata.com/de/sql/ SQL-Tutorial]
*[http://sqltutor.fsv.cvut.cz/cgi-bin/sqltutor GNU SQLTutor]
*[http://sqltutor.fsv.cvut.cz/cgi-bin/sqltutor GNU SQLTutor]
Zeile 816: Zeile 94:
*[https://docs.microsoft.com/en-us/sql/t-sql/language-reference?view=sql-server-ver15 Transact-SQL Reference (Database Engine)]
*[https://docs.microsoft.com/en-us/sql/t-sql/language-reference?view=sql-server-ver15 Transact-SQL Reference (Database Engine)]


==Siehe auch==
===Einzelnachweise===
 
*[[Data Manipulation Language]]
*[[Data Definition Language]]
*[[Data Control Language]]
*[[Transaction Control Language]]
*[[SQL-Injection]]
*[[SchemaSQL]]
*[[Continuous Query Language]]
*[[Liste der Datenbankmanagementsysteme]]
*[[Bereichsabfrage]]
 
==Einzelnachweise==
<references />
<references />
==Testfragen==
<div class="toccolours mw-collapsible mw-collapsed">
''Testfrage 1''
<div class="mw-collapsible-content">'''Antwort1'''</div>
</div>
<div class="toccolours mw-collapsible mw-collapsed">
''Testfrage 2''
<div class="mw-collapsible-content">'''Antwort2'''</div>
</div>
<div class="toccolours mw-collapsible mw-collapsed">
''Testfrage 3''
<div class="mw-collapsible-content">'''Antwort3'''</div>
</div>
<div class="toccolours mw-collapsible mw-collapsed">
''Testfrage 4''
<div class="mw-collapsible-content">'''Antwort4'''</div>
</div>
<div class="toccolours mw-collapsible mw-collapsed">
''Testfrage 5''
<div class="mw-collapsible-content">'''Antwort5'''</div>
</div>


{{Normdaten|TYP=s|GND=4134010-3|LCCN=sh/86/6628}}


[[index.php?title=Kategorie:SQL| ]]
[[Kategorie:SQL]]
[[Kategorie:Datenbanksprache]]
[[Kategorie:Abkürzung]]
[[Kategorie:Abkürzung]]
[[Kategorie:Programmiersprache mit einem ISO-Standard]]
[[Kategorie:SQL]]

Aktuelle Version vom 6. November 2024, 12:51 Uhr

topic - Kurzbeschreibung

Beschreibung

SQL (offizielle Aussprache [Vorlage:IPA], mitunter auch [Vorlage:IPA]; auf Deutsch auch häufig die deutsche Aussprache der Buchstaben) ist eine Datenbanksprache zur Definition von Datenstrukturen in relationalen Datenbanken sowie zum Bearbeiten (Einfügen, Verändern, Löschen) und Abfragen von darauf basierenden Datenbeständen.

Die Sprache basiert auf der relationalen Algebra, ihre Syntax ist relativ einfach aufgebaut und semantisch an die englische Umgangssprache angelehnt. Ein gemeinsames Gremium von ISO und IEC standardisiert die Sprache unter Mitwirkung nationaler Normungsgremien wie ANSI oder DIN. Durch den Einsatz von SQL strebt man die Unabhängigkeit der Anwendungen vom eingesetzten Datenbankmanagementsystem an.

Die Bezeichnung SQL wird im allgemeinen Sprachgebrauch als Abkürzung für „Structured Query Language“ (auf Deutsch: „Strukturierte Abfrage-Sprache“) aufgefasst, obwohl sie laut Standard ein eigenständiger Name ist. Die Bezeichnung leitet sich von dem Vorgänger SEQUEL ([[[:Vorlage:IPA]]], Structured English Query Language) ab, welche mit Beteiligung von Edgar F. Codd (IBM) in den 1970er Jahren von Donald D. Chamberlin und Raymond F. Boyce entwickelt wurde. SEQUEL wurde später in SQL umbenannt, weil SEQUEL ein eingetragenes Warenzeichen der Hawker Siddeley Aircraft Company ist.[1]

Sprachelemente

Bestandteile von SQL

SQL-Befehle lassen sich in fünf Kategorien unterteilen (Zuordnung nach der Theorie der Datenbanksprachen in Klammern):

Die Bezeichnung SQL bezieht sich auf das englische Wort Vorlage:". Mit Abfragen werden die in einer Datenbank gespeicherten Daten abgerufen, also dem Benutzer oder einer Anwendersoftware zur Verfügung gestellt.

Das Ergebnis einer Abfrage sieht wiederum aus wie eine Tabelle und kann oft auch wie eine Tabelle angezeigt, bearbeitet und weiterverwendet werden. Vorlage:Siehe auch

Chronologie

Jahr Beschreibung
1975 SEQUEL = Structured English Query Language, der Vorläufer von SQL, wird für das Projekt System R von IBM entwickelt.
1979 SQL gelangt mit Oracle V2 erstmals durch Relational Software Inc. auf den Markt.
1986 SQL1 wird von ANSI als Standard verabschiedet.
1987 SQL1 wird von der Internationalen Organisation für Normung (ISO) als Standard verabschiedet und 1989 nochmals überarbeitet.
1992 Der Standard SQL2 oder SQL-92 wird von der ISO verabschiedet.
1999 SQL3 oder SQL:1999 wird verabschiedet. Im Rahmen dieser Überarbeitung werden weitere wichtige Features (wie etwa Trigger oder rekursive Abfragen) hinzugefügt.
2003 SQL:2003. Als neue Features werden aufgenommen SQL/XML, Window functions, Sequences.
2006 SQL/XML:2006. Erweiterungen für SQL/XML[2].
2008 SQL:2008 bzw. ISO/IEC 9075:2008. Als neue Features werden aufgenommen INSTEAD OF-Trigger, TRUNCATE-Statement und FETCH Klausel.
2011 SQL:2011 bzw. ISO/IEC 9075:2011. Als neue Features werden aufgenommen „Zeitbezogene Daten“ (PERIOD FOR). Es gibt Erweiterungen für Window functions und die FETCH Klausel.
2016 SQL:2016 bzw. ISO/IEC 9075:2016. Als neue Features werden aufgenommen JSON und „row pattern matching“.
2019 SQL/MDA:2019. Erweiterungen für einen Datentyp „mehrdimensionales Feld“.

Syntax

Sicherheit

Dokumentation

RFC

Man-Page

Info-Pages

Siehe auch

Links

Projekt-Homepage

Weblinks

Vorlage:Wikibooks

Einzelnachweise

Testfragen

Testfrage 1

Antwort1

Testfrage 2

Antwort2

Testfrage 3

Antwort3

Testfrage 4

Antwort4

Testfrage 5

Antwort5