Modelagem de relações 1:N com chaves externas

Introdução aos bancos de dados relacionais em SQL

Timo Grossenbacher

Data Journalist

O modelo atual do banco de dados

Introdução aos bancos de dados relacionais em SQL

O próximo modelo de banco de dados

Introdução aos bancos de dados relacionais em SQL

Implementação de relações com chaves externas

  • Uma chave externa (FK, Foreign Key) aponta para a chave primária (PK, Primary Key) de outra tabela
  • O domínio da FK precisa ser igual ao domínio da PK
  • Cada valor de FK precisa estar na PK da outra tabela (restrição de FK ou “integridade referencial”)
  • FKs não são chaves reais
Introdução aos bancos de dados relacionais em SQL

Uma pergunta

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
Introdução aos bancos de dados relacionais em SQL

Especificação de chaves 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');
Introdução aos bancos de dados relacionais em SQL

Especificação de chaves externas para tabelas já existentes

ALTER TABLE a 
ADD CONSTRAINT a_fkey FOREIGN KEY (b_id) REFERENCES b (id);
Introdução aos bancos de dados relacionais em SQL

Vamos implementar isso!

Introdução aos bancos de dados relacionais em SQL

Preparing Video For Download...