Introdução ao SQL/Criando Tabelas
Podemos criar uma tabela qualquer dentro de um banco de dados. A sintaxe básica para criarmos é:
sql
-- Criação do banco de dados
CREATE DATABASE Biblioteca;
-- Utilização do banco de dados
USE Biblioteca;
CREATE TABLE é o comando para criação da tabela e deve ser seguida pelo nome que daremos à tabela. Dentro do comando, devemos definir os nomes dos campos de acordo com a conveniência do banco de dados, e determinar o tipo de dado que poderá ser incluído neste campo. Na seção abaixo Tipo de Dados estão especificados os tipos mais comuns encontrados nos SGBDs. PRIMARY KEY define a chave primária da tabela, isto é, o campo que serve como chave da tabela e que não pode ser repetido.
Se desejamos que um campo seja de preenchimento obrigatório, devemos inserir NOT NULL na frente do campo determinado.
-- Criação da tabela Livros
CREATE TABLE Livros (
ID INT PRIMARY KEY,
Titulo VARCHAR(100),
Autor VARCHAR(100),
AnoPublicacao INT,
Genero VARCHAR(50)
);
Se desejamos que um campo seja de auto-incremento, devemos inserir AUTO_INCREMENT na frente do campo determinado. Isto pode ser utilizado por exemplo, para automatizar um código que sirva de chave primária de uma tabela:
-- Inserção de registros na tabela Livros
INSERT INTO Livros (ID, Titulo, Autor, AnoPublicacao, Genero)
VALUES
(1, 'Dom Quixote', 'Miguel de Cervantes', 1605, 'Romance'),
(2, '1984', 'George Orwell', 1949, 'Ficção Distópica'),
(3, 'O Senhor dos Anéis', 'J.R.R. Tolkien', 1954, 'Fantasia'),
(4, 'Crime e Castigo', 'Fiódor Dostoiévski', 1866, 'Romance'),
(5, 'Orgulho e Preconceito', 'Jane Austen', 1813, 'Romance');
Tipos de Dados
editarTipos de dados definem os tipos de informação que podem ser inseridos em um campo. Somente dados do mesmo tipo do campo poderão ser inseridos. Os tipos suportados por um banco de dados podem variar de SGBD para SGBD, mas descrevemos a seguir os principais tipos encontrados na maior parte dos gerenciadores:
Tipo | Abreviação genérica | Descrição |
---|---|---|
INTEIRO | INT ou INTEGER | Números inteiros. Existem outros tipos de números inteiros de acordo com o gerenciador utilizado. |
REAL | DOUBLE ou REAL | Números reais. Permitem armazenar todo tipo de número não inteiro. Existem outros tipos de números reais de acordo com o gerenciador utilizado. |
CARACTER | CHAR (NÚMERO) | Caracter. Permite a inclusão de dados alfanuméricos com tamanho pré-definido. O número de caracteres é definido entre os parênteses. |
DATA | DATE | Data. Existem diversos tipos de datas de acordo com o gerenciador utilizado. |
BOOLEANO | BOOLEAN | Armazena um bit de informação, utilizado para verdadeiro ou falso. |
{Utilizando a instrução Insert Através da instrução Insert, podemos adicionar uma ou mais linhas para uma tabela do banco de dados:
INSERT INTO NOME_DA_TABELA (coluna1, coluna2, coluna3, ....colunaN) VALUES (valor1, valor2, valor3, ..., valorN).
Exemplo
editarComo exemplo do uso do comando CREATE TABLE, imaginemos a necessidade de uma tabela que deva possuir os dados dos clientes de uma loja.
-- Criação da tabela Autores
CREATE TABLE Autores (
ID INT PRIMARY KEY,
Nome VARCHAR(100),
Nacionalidade VARCHAR(50),
DataNascimento DATE
);
Neste comando, criaremos uma tabela chamada Cliente. Esta tabela contém quatro campos: o primeiro campo é o Código do cliente. Este campo será utilizado como chave primária de forma que não poderá se repetir nunca. Desta forma o campo deve ser sempre preenchido (NOT NULL), é numérico do tipo inteiro (INT) e deve auto-incrementar de acordo com o número de clientes que for incluído. O campo Nome é do tipo VARCHAR (60), ou seja aceita dados alfa-numéricos com até 60 caracteres. No entanto se um nome for inserido com menos de 60 caracteres, o número de bytes consumidos pelo campo será de acordo com o nome inserido. O campo de Data_Nascimento é do tipo DATE, ou seja, uma data, que no entanto não de preenchimento obrigatório (por isto não foi declarado o NOT NULL). O campo Telefone foi determinado como sendo alfa-numérico com oito caracteres definidos, e mesmo que sejam utilizados menos caracteres, o número de bytes consumidos serão sempre os mesmos independente dos dados. Isto é útil para dados alfanuméricos que não variam de tamanho, como o caso de UF no Brasil, cuja abreviação sempre são de dois caracteres. A instrução PRIMARY KEY define qual dos campos será a chave primária e não pode ser repetido, sendo o diferenciador entre os diversos clientes que sejam inseridos nesta tabela.
servidor de banco de dados utilizará todas as colunas da tabela informada. Veja alguns exemplos de uso da instrução Insert:
INSERT INTO CLIENTES (CODIGO, NOME, SEXO) VALUES (1, 'Natália da Silva', 'F'); INSERT INTO CIDADES (CODCIDADE, CODPAIS, NOMECIDADE, DDD) VALUES (4, 55, 'Curitiba', '31'); INSERT INTO ITENS VALUES (1, 13, 200.87);
Describe
editarApós criarmos uma tabela, elas podem ser manipuladas de diversas formas, inserindo, alterando ou excluindo dados. Podemos visualizar a estrutura e campos de uma tabela criada utilizando o comando DESCRIBE ou DESC:
DESCRIBE Nome_Tabela;#
Ou:
DESC Nome_Tabela;
Regras de Integridade
editarEstudamos acima como criar uma tabela simples. No entanto, ao criarmos uma tabela dentro de um banco de dados devemos ter em mente as Regras de Integridade, que garantam a consistência, integridade e não redundância dos dados. Entre estas regras podemos englobar as chaves primárias, checagem e chave estrangeira.
Chave primária
editarNo exemplo acima vimos a seguinte declaração na criação da tabela:
PRIMARY KEY ( campo_x,...);
Esta declaração diz que os campos inseridos entre os parênteses formam a chave primária da tabela. A chave primária funcionam como os campos que diferenciam os dados uns dos outros, e que não podem ser repetidos de nenhuma forma. Por exemplo, em nossa tabela Cliente, o código do Cliente funciona como a chave-primária, ou seja, os clientes podem até ter o mesmo nome, endereço ou telefone, mas terão códigos diferentes uns dos outros. Se dois códigos iguais forem inseridos o SGBD retornará erro.
Checagem
editarPodemos inserir em uma tabela depois do campo chave primária e antes do último parêntese a cláusula:
CHECK Nome _Campo IN (valor1 , valor2, valor n);
Esta cláusula força a um campo a aceitar apenas os valores especificados entre os parênteses. Isto pode ser útil para definir, por exemplo, campos como sexo. Desta forma forçamos as opções através de:
CHECK Sexo IN ('M','F');
Onde o campo Sexo só podem assumir a forma M (Masculino) ou F (Feminino).
Infelizmente, o MySQL não suporta restrições de verificação SQL. Você pode defini-los em sua consulta DDL por motivos de compatibilidade, mas eles simplesmente são ignorados.
Chave estrangeira
editarA chave estrangeira é uma cláusula que deve ser incluída quando possuímos mais de duas tabelas em um banco de dados. Através da chave estrangeira estabelecemos as relações entre duas ou mais tabelas. A chave estrangeira desta forma referencia o campo que é chave primária de outra tabela. Tabela.
-- Inserção de registros na tabela Autores
INSERT INTO Autores (ID, Nome, Nacionalidade, DataNascimento)
VALUES
(1, 'Miguel de Cervantes', 'Espanha', '1547-09-29'),
(2, 'George Orwell', 'Inglaterra', '1903-06-25'),
(3, 'J.R.R. Tolkien', 'Inglaterra', '1892-01-03'),
(4, 'Fiódor Dostoiévski', 'Rússia', '1821-11-11'),
(5, 'Jane Austen', 'Inglaterra', '1775-12-16');
>>
niciar download Comece a usar! Start Download · Free Download · Start Now · Download Free