SQL - Standard Constraint: Ein Anfängerleitfaden

Hallo da draußen, ambitionierte SQL-Enthusiasten! Heute tauchen wir in die wunderbare Welt der SQL-Standard Constraints ein. Machen Sie sich keine Sorgen, wenn Sie neu im Programmieren sind – ich werde Ihr freundlicher Guide auf dieser Reise sein und alles Schritt für Schritt erklären. Also, holen Sie sich eine Tasse Kaffee und los geht's!

SQL - Default Constraint

Die SQL DEFAULT Constraint

Stellen Sie sich vor, Sie füllen ein Formular aus, und es gibt ein Feld, das "Land" heißt. Wenn die meisten Ihrer Benutzer aus den Vereinigten Staaten kommen, wäre es nicht schön, wenn bereits "USA" eingegeben wäre? Genau das macht die DEFAULT Constraint in SQL – sie bietet einen Standardwert für eine Spalte, wenn kein spezifischer Wert angegeben wird.

Wie es funktioniert

Wenn Sie eine Tabelle erstellen oder eine neue Spalte hinzufügen, können Sie einen Standardwert angeben. Dieser Wert wird automatisch eingefügt, wenn Sie bei der Hinzufügung eines neuen Datensatzes keinen bestimmten Wert angeben.

Sehen wir uns ein Beispiel an:

CREATE TABLE Kunden (
KundenID int NOT NULL,
Kundenname varchar(255) NOT NULL,
Kontaktname varchar(255),
Land varchar(255) DEFAULT 'USA'
);

In diesem Beispiel haben wir eine "Kunden" Tabelle erstellt. Die "Land" Spalte hat eine DEFAULT Constraint auf 'USA' gesetzt. Das bedeutet, wenn wir bei der Hinzufügung eines neuen Kunden kein Land angeben, wird es automatisch auf 'USA' gesetzt.

Daten mit DEFAULT einfügen

Nun fügen wir einige Kunden in unsere Tabelle ein:

INSERT INTO Kunden (KundenID, Kundenname, Kontaktname)
VALUES (1, 'John Doe', 'John');

INSERT INTO Kunden (KundenID, Kundenname, Kontaktname, Land)
VALUES (2, 'Jane Smith', 'Jane', 'Kanada');

Nachdem wir diese INSERT-Anweisungen ausgeführt haben, sähe unsere Tabelle如此 aus:

KundenID Kundenname Kontaktname Land
1 John Doe John USA
2 Jane Smith Jane Kanada

Beachten Sie, wie bei John Doe das Land automatisch auf 'USA' gesetzt wird, während bei Jane Smith das Land explizit auf 'Kanada' gesetzt ist.

"DEFAULT" als Wert verwenden

Manchmal möchten Sie den Standardwert explizit verwenden, auch wenn Sie Werte für andere Spalten angeben. SQL ermöglicht dies durch die Verwendung des Schlüsselworts DEFAULT.

INSERT INTO Kunden (KundenID, Kundenname, Kontaktname, Land)
VALUES (3, 'Bob Johnson', 'Bob', DEFAULT);

Dies würde einen neuen Datensatz mit 'USA' als Land einfügen, genau wie wenn wir die Land-Spalte überhaupt weggelassen hätten.

Standard Constraint zu einer vorhandenen Spalte hinzufügen

Was ist, wenn Sie bereits Ihre Tabelle erstellt haben, aber jetzt eine Standard Constraint hinzufügen möchten? Kein Problem! SQL hat Sie abgedeckt.

Die exakte Syntax kann je nach Ihrem Datenbanksystem leicht variieren, aber hier ist ein allgemeines Beispiel:

ALTER TABLE Kunden
ALTER COLUMN Land SET DEFAULT 'USA';

Dieser Befehl bearbeitet die vorhandene "Kunden" Tabelle und setzt den Standardwert für die "Land" Spalte auf 'USA'.

Ein Wort der Warnung

Denken Sie daran, dass das Hinzufügen einer Standard Constraint die bestehenden Daten nicht beeinflusst. Es gilt nur für neue Datensätze oder Updates. Wenn Sie also zuvor leere Werte in Ihrer Land-Spalte hatten, bleiben diese leer, bis Sie sie aktualisieren.

Standard Constraint entfernen

Genau wie wir Standard Constraints hinzufügen können, können wir sie auch entfernen. Dies wird als "Entfernen" des Constraints bezeichnet.

Again, the exact syntax might vary, but here's a general example:

ALTER TABLE Kunden
ALTER COLUMN Land DROP DEFAULT;

Dieser Befehl entfernt die Standard Constraint von der "Land" Spalte in der "Kunden" Tabelle.

Wann man eine Standard Constraint entfernt

Sie möchten möglicherweise eine Standard Constraint entfernen, wenn:

  1. Der Standardwert nicht mehr relevant ist
  2. Sie manuelle Eingaben für diese Spalte erzwingen möchten
  3. Sie die Spalte vollständig entfernen möchten

Praktische Verwendung von Standard Constraints

Standard Constraints sind in vielen realen Szenarien äußerst nützlich. Hier sind einige Beispiele:

  1. Zeitstempel: Sie können Standard verwenden, um automatisch die aktuelle Zeit bei der Einfügung eines Datensatzes zu protokollieren.
CREATE TABLE Aufträge (
AuftragsID int NOT NULL,
Produktname varchar(255) NOT NULL,
Auftragsdatum datetime DEFAULT CURRENT_TIMESTAMP
);
  1. Statusflags: Für Spalten, die Status oder Zustände darstellen, können Sie einen Standard初始状态 festlegen.
CREATE TABLE Aufgaben (
AufgabenID int NOT NULL,
Aufgabenname varchar(255) NOT NULL,
Erledigt bit DEFAULT 0
);
  1. Konfigurationseinstellungen: Bei der Speicherung von Benutzereinstellungen können Sie vernünftige Standards festlegen.
CREATE TABLE Benutzereinstellungen (
BenutzernID int NOT NULL,
Thema varchar(50) DEFAULT 'Hell',
BenachrichtigungenAktiviert bit DEFAULT 1
);

Fazit

Und das war's, Leute! Wir haben die Welt der SQL-Standard Constraints bereist. Wir haben gesehen, wie man sie erstellt, verwendet, zu vorhandenen Spalten hinzufügt und sogar entfernt, wenn sie nicht mehr benötigt werden.

Erinnern Sie sich daran, dass Standard Constraints wie hilfreiche kleine Elfen in Ihrer Datenbank sind, die die Lücken füllen, wenn Sie die Informationen vergessen oder nicht zur Hand haben. Sie können Ihnen Zeit sparen, Fehler reduzieren und Ihre Daten konsistenter machen.

Während Sie Ihre SQL-Abenteuer fortsetzen, werden Sie viele weitere Verwendungsmöglichkeiten für Standard Constraints finden. Sie sind ein einfaches, aber mächtiges Werkzeug in Ihrem SQL-Werkzeugkasten. Also, los geht's und constrainten Sie! Frohes Coden!

Credits: Image by storyset