Chaves e superchaves

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 modelo de banco de dados com chaves primárias

Introdução aos bancos de dados relacionais em SQL

O que é uma chave?

  • Atributo(s) que identifica(m) um registro de forma exclusiva
  • Contanto que os atributos possam ser removidos: superchave
  • Se não for possível remover mais atributos: chave ou superchave mínima
Introdução aos bancos de dados relacionais em SQL
     license_no     | serial_no |    make    |  model  | year
 -------------------+-----------+------------+---------+------
 Texas ABC-739      | A69352    | Ford       | Mustang |    2
 Florida TVP-347    | B43696    | Oldsmobile | Cutlass |    5
 New York MPO-22    | X83554    | Oldsmobile | Delta   |    1
 California 432-TFY | C43742    | Mercedes   | 190-D   |   99
 California RSK-629 | Y82935    | Toyota     | Camry   |    4
 Texas RSK-629      | U028365   | Jaguar     | XJS     |    4

SK1 = {license_no, serial_no, make, model, year}

SK2 = {license_no, serial_no, make, model}

SK3 = {make, model, year}, SK4 = {license_no, serial_no}, SKi, ..., SKn

Adaptado de Elmasri, Navathe (2011): Fundamentals of Database Systems, 6th Ed., Pearson

Introdução aos bancos de dados relacionais em SQL
     license_no     | serial_no |    make    |  model  | year
 -------------------+-----------+------------+---------+------
 Texas ABC-739      | A69352    | Ford       | Mustang |    2
 Florida TVP-347    | B43696    | Oldsmobile | Cutlass |    5
 New York MPO-22    | X83554    | Oldsmobile | Delta   |    1
 California 432-TFY | C43742    | Mercedes   | 190-D   |   99
 California RSK-629 | Y82935    | Toyota     | Camry   |    4
 Texas RSK-629      | U028365   | Jaguar     | XJS     |    4

K1 = {license_no}; K2 = {serial_no}; K3 = {model}; K4 = {make, year}

  • K1 a 3 têm só um atributo
  • Tirar “make” ou “year” da K4 acabaria com duplicatas
  • Somente uma chave candidata pode ser a chave escolhida
Introdução aos bancos de dados relacionais em SQL

Vamos descobrir algumas chaves!

Introdução aos bancos de dados relacionais em SQL

Preparing Video For Download...