Atualização do banco de dados à medida que a estrutura muda

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 atual do banco de dados

Introdução aos bancos de dados relacionais em SQL

DISTINCT: armazene apenas dados distintos nas novas tabelas

SELECT COUNT(*)
FROM university_professors;
 count
 -----
 1377
SELECT COUNT(DISTINCT organization) 
FROM university_professors;
 count
 -----
 1287
Introdução aos bancos de dados relacionais em SQL

Insira registros distintos nas novas tabelas

INSERT INTO organizations 
SELECT DISTINCT organization, 
    organization_sector
FROM university_professors;
Output: INSERT 0 1287
INSERT INTO organizations 
SELECT organization, 
    organization_sector
FROM university_professors;
Output: INSERT 0 1377
Introdução aos bancos de dados relacionais em SQL

A instrução INSERT INTO

INSERT INTO table_name (column_a, column_b)
VALUES ("value_a", "value_b");
Introdução aos bancos de dados relacionais em SQL

RENAME COLUMN: renomeie uma coluna

CREATE TABLE affiliations (
 firstname text,
 lastname text,
 university_shortname text,
 function text,
 organisation text
);
ALTER TABLE table_name
RENAME COLUMN old_name TO new_name;
Introdução aos bancos de dados relacionais em SQL

DROP COLUMN: renomeie uma coluna

CREATE TABLE affiliations (
 firstname text,
 lastname text,
 university_shortname text,
 function text,
 organization text
);
ALTER TABLE table_name
DROP COLUMN column_name;
Introdução aos bancos de dados relacionais em SQL
SELECT DISTINCT firstname, lastname, 
    university_shortname 
FROM university_professors
ORDER BY lastname;
-[ RECORD 1 ]--------+-------------
firstname            | Karl
lastname             | Aberer
university_shortname | EPF
-[ RECORD 2 ]--------+-------------
firstname            | Reza Shokrollah
lastname             | Abhari
university_shortname | ETH
-[ RECORD 3 ]--------+-------------
firstname            | Georges
lastname             | Abou Jaoudé
university_shortname | EPF
(truncated)

(551 records)
SELECT DISTINCT firstname, lastname 
FROM university_professors
ORDER BY lastname;
-[ RECORD 1 ]----------------------
firstname | Karl
lastname  | Aberer
-[ RECORD 2 ]----------------------
firstname | Reza Shokrollah
lastname  | Abhari
-[ RECORD 3 ]----------------------
firstname | Georges
lastname  | Abou Jaoudé
(truncated)

(551 records)
Introdução aos bancos de dados relacionais em SQL

Um professor é identificado exclusivamente pelo nome e sobrenome

Introdução aos bancos de dados relacionais em SQL

Vamos começar a trabalhar!

Introdução aos bancos de dados relacionais em SQL

Preparing Video For Download...