Claves sustitutas

Introducción a las bases de datos relacionales en SQL

Timo Grossenbacher

Data Journalist

Claves sustitutas

  • Las claves primarias deben construirse a partir del menor número posible de columnas.
  • Las claves primarias nunca deben cambiar con el tiempo.
Introducción a las bases de datos relacionales en 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
Introducción a las bases de datos relacionales en SQL

Añadir una clave sustituta con tipo de datos 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
Introducción a las bases de datos relacionales en SQL

Añadir una clave sustituta con tipo de datos serial (cont.)

INSERT INTO cars
VALUES ('Opel', 'Astra', 'green', 1);
duplicate key value violates unique constraint "id_pkey"
DETAIL:  Key (id)=(1) already exists.
  • «id» identifica de forma única los registros de la tabla, lo que resulta útil para hacer referencias.
Introducción a las bases de datos relacionales en SQL

Otro tipo de clave sustituta

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);
Introducción a las bases de datos relacionales en SQL

Introducción a las bases de datos relacionales en SQL

¡Probemos esto!

Introducción a las bases de datos relacionales en SQL

Preparing Video For Download...