Modelo de relaciones 1:N con claves externas

Introducción a las bases de datos relacionales en SQL

Timo Grossenbacher

Data Journalist

El modelo actual de base de datos

Introducción a las bases de datos relacionales en SQL

El siguiente modelo de base de datos

Introducción a las bases de datos relacionales en SQL

Implementación de relaciones con claves externas

  • Una clave externa (FK) apunta a la clave principal (PK) de otra tabla.
  • El dominio de FK debe ser igual al dominio de PK.
  • Cada valor de FK debe existir en PK de la otra tabla (restricción FK o «integridad referencial»).
  • Las FK no son claves reales.
Introducción a las bases de datos relacionales en SQL

Una consulta

SELECT * FROM professors LIMIT 8;
 id |    firstname    |  lastname   | university_s..
  --+-----------------+-------------+-------------
  1 | Karl            | Aberer      | EPF
  2 | Reza Shokrollah | Abhari      | ETH
  3 | Georges         | Abou Jaoudé | EPF
  4 | Hugues          | Abriel      | UBE
  5 | Daniel          | Aebersold   | UBE
  6 | Marcelo         | Aebi        | ULA
  7 | Christoph       | Aebi        | UBE
  8 | Patrick         | Aebischer   | EPF
SELECT * FROM universities;
 id  |   university   | university_city
<hr />--+----------------+-----------------
 EPF | ETH Lausanne   | Lausanne
 ETH | ETH Zürich     | Zurich
 UBA | Uni Basel      | Basel
 UBE | Uni Bern       | Bern
 UFR | Uni Freiburg   | Fribourg
 UGE | Uni Genf       | Geneva
 ULA | Uni Lausanne   | Lausanne
 UNE | Uni Neuenburg  | Neuchâtel
 USG | Uni St. Gallen | Saint Gallen
 USI | USI Lugano     | Lugano
 UZH | Uni Zürich     | Zurich
Introducción a las bases de datos relacionales en SQL

Especificar claves externas

CREATE TABLE manufacturers (
 name varchar(255) PRIMARY KEY);

INSERT INTO manufacturers 
VALUES ('Ford'), ('VW'), ('GM');

CREATE TABLE cars ( model varchar(255) PRIMARY KEY, manufacturer_name varchar(255) REFERENCES manufacturers (name)); INSERT INTO cars VALUES ('Ranger', 'Ford'), ('Beetle', 'VW');
-- Throws an error!
INSERT INTO cars 
VALUES ('Tundra', 'Toyota');
Introducción a las bases de datos relacionales en SQL

Especificar claves externas para tablas existentes

ALTER TABLE a 
ADD CONSTRAINT a_fkey FOREIGN KEY (b_id) REFERENCES b (id);
Introducción a las bases de datos relacionales en SQL

¡Pongamos esto en práctica!

Introducción a las bases de datos relacionales en SQL

Preparing Video For Download...