Surrogatschlüssel

Einführung in relationale Datenbanken in SQL

Timo Grossenbacher

Data Journalist

Surrogatschlüssel

  • Primärschlüssel sollten aus so wenigen Spalten wie möglich erstellt werden.
  • Primärschlüssel sollten sich im Laufe der Zeit nie ändern.
Einführung in relationale Datenbanken in SQL
     license_no     | serial_no |    make    |  model  | color
 -------------------+-----------+------------+---------+------
 Texas ABC-739      | A69352    | Ford       | Mustang | blue
 Florida TVP-347    | B43696    | Oldsmobile | Cutlass | black
 New York MPO-22    | X83554    | Oldsmobile | Delta   | silver
 California 432-TFY | C43742    | Mercedes   | 190-D   | champagne
 California RSK-629 | Y82935    | Toyota     | Camry   | red
 Texas RSK-629      | U028365   | Jaguar     | XJS     | blue
    make    |  model  | color
 -----------+---------+------
 Ford       | Mustang | blue
 Oldsmobile | Cutlass | black
 Oldsmobile | Delta   | silver
 Mercedes   | 190-D   | champagne
 Toyota     | Camry   | red
 Jaguar     | XJS     | blue
Einführung in relationale Datenbanken in SQL

Surrogatschlüssels mit Datentyp „serial“

ALTER TABLE cars
ADD COLUMN id serial PRIMARY KEY;

INSERT INTO cars VALUES ('Volkswagen', 'Blitz', 'black');
    make    |  model  | color       | id
  ----------+---------+-------------+-------------
 Ford       | Mustang | blue        | 1
 Oldsmobile | Cutlass | black       | 2
 Oldsmobile | Delta   | silver      | 3
 Mercedes   | 190-D   | champagne   | 4
 Toyota     | Camry   | red         | 5
 Jaguar     | XJS     | blue        | 6
 Volkswagen | Blitz   | black       | 7
Einführung in relationale Datenbanken in SQL

Surrogatschlüssels mit Datentyp „serial“ (Forts.)

INSERT INTO cars
VALUES ('Opel', 'Astra', 'green', 1);
duplicate key value violates unique constraint "id_pkey"
DETAIL:  Key (id)=(1) already exists.
  • „id“ identifiziert die Datensätze in der Tabelle eindeutig – nützlich für Verweise!
Einführung in relationale Datenbanken in SQL

Eine andere Art von Surrogatschlüssel

ALTER TABLE table_name
ADD COLUMN column_c varchar(256);

UPDATE table_name
SET column_c = CONCAT(column_a, column_b);

ALTER TABLE table_name ADD CONSTRAINT pk PRIMARY KEY (column_c);
Einführung in relationale Datenbanken in SQL

Einführung in relationale Datenbanken in SQL

Probieren wir es aus!

Einführung in relationale Datenbanken in SQL

Preparing Video For Download...