Ministério da Educação - MEC
Secretaria de Educação Profissional e Tecnológica (SETEC)
Instituto Federal de Educação, Ciência e Tecnologia do Ceará
Administrador de Banco de Dados
Francisco Edmar Vasconcelos Pereira
Ministério da Educação - MEC
Secretaria de Educação Profissional e Tecnológica (SETEC)
Instituto Federal de Educação, Ciência e Tecnologia do Ceará
CURSO ADMINISTRADOR DE BANCO DE DADOS
PROF. FRANCISCO EDMAR VASCONCELOS PEREIRA
CURSO FIC
CRÉDITOS
Presidente
Dilma Vana Rousseff
Ministro da Educação
Aloizio Mercadante Oliva
Secretaria de Educação Profissional e
Tecnológica
Marco Antonio de Oliveira
Reitor do IFCE
Cláudio Ricardo Gomes de Lima
Pró-Reitor de Extensão
Gutenberg Albuquerque Filho
Pró-Reitor de Ensino
Gilmar Lopes Ribeiro
Pró-Reitor de Administração
Virgilio Augusto Sales Araripe
Diretor Geral Campus Fortaleza
Antonio Moises Filho de Oliveira Mota
Diretor de Ensino Campus Fortaleza
José Eduardo Souza Bastos
Coordenador Geral – Reitoria
Jose Wally Mendonça Menezes
Coordenador Adjunto - Reitoria
Armênia Chaves Fernandes Vieira
Supervisão - Reitoria
Daniel Ferreira de Castro
André Monteiro de Castro
Coordenador Adjunto - Campus
Fortaleza
Fabio Alencar Mendonça
Elaboração do conteúdo
Francisco Edmar Vasconcelos Pereira
Equipe Técnica
Manuela Pinheiro dos Santos
Marciana Matos da Costa
Kaio Lucas Ribeiro de Queiroz
Vanessa Barbosa da Silva Dias
Edmilson Moreira Lima Filho
Vitor de Carvalho Melo Lopes
Rogers Guedes Feitosa Teixeira
Orientadora
Barbara Luana Sousa Marques
O QUE É O PRONATEC?
Criado no dia 26 de Outubro de 2011 com a sanção da Lei nº 12.513/2011 pela Presidenta
Dilma Rousseff, o Programa Nacional de Acesso ao Ensino Técnico e Emprego (Pronatec) tem
como objetivo principal expandir, interiorizar e democratizar a oferta de cursos de Educação
Profissional e Tecnológica (EPT) para a população brasileira. Para tanto, prevê uma série de
subprogramas, projetos e ações de assistência técnica e financeira que juntos oferecerão oito
milhões de vagas a brasileiros de diferentes perfis nos próximos quatro anos. Os destaques do
Pronatec são:
• Criação da Bolsa-Formação;
• Criação do FIES Técnico;
• Consolidação da Rede e-Tec Brasil;
• Fomento às redes estaduais de EPT por intermédio do Brasil Profissionalizado;
• Expansão da Rede Federal de Educação Profissional Tecnológica (EPT).
A principal novidade do Pronatec é a criação da Bolsa-Formação, que permitirá a oferta
de vagas em cursos técnicos e de Formação Inicial e Continuada (FIC), também conhecidos
como cursos de qualificação. Oferecidos gratuitamente a trabalhadores, estudantes e pessoas em
vulnerabilidade social, esses cursos presenciais serão realizados pela Rede Federal de Educação
Profissional, Científica e Tecnológica, por escolas estaduais de EPT e por unidades de serviços
nacionais de aprendizagem como o SENAC e o SENAI.
Objetivos
• Expandir, interiorizar e democratizar a oferta de cursos de Educação Profissional
Técnica de nível médio e de cursos e programas de formação inicial e continuada de
trabalhadores;
• Fomentar e apoiar a expansão da rede física de atendimento da Educação
Profissional e Tecnológica;
• Contribuir para a melhoria da qualidade do Ensino Médio Público, por meio da
Educação Profissional;
• Ampliar as oportunidades educacionais dos trabalhadores por meio do incremento da
formação profissional.
Ações
• Ampliação de vagas e expansão da Rede Federal de Educação Profissional e
Tecnológica;
• Fomento à ampliação de vagas e à expansão das redes estaduais de Educação
Profissional;
• Incentivo à ampliação de vagas e à expansão da rede física de atendimento dos
Serviços Nacionais de Aprendizagem;
• Oferta de Bolsa-Formação, nas modalidades:
• Bolsa-Formação Estudante;
• Bolsa-Formação Trabalhador.
• Atendimento a beneficiários do Seguro-Desemprego;
Sumário
Sistema operacional Microsoft Windows XP ................................................................................. 4
Inicando o Windows XP .............................................................................................................4
Desligar o computador ............................................................................................................... 5
Área de trabalho .......................................................................................................................... 5
Menu Iniciar ................................................................................................................................ 7
Menu todos os programas ....................................................................................................... 9
Abrindo programas ...................................................................................................................... 9
Janelas....................................................................................................................................... 11
Exercícios ...................................................................................................................................... 12
Trabalhando com múltiplas janelas ........................................................................................... 13
Organizando a área de trabalho ................................................................................................. 14
Organizando Ícones na área de trabalho ................................................................................... 15
Planilha de Cálculo Microsoft Microsoft Office Excel ............................................................ .....16
Iniciando o Documento .............................................................................................................15
Inserindo e Excluindo Planilhas ................................................................................................25
Renoameando Planinhas ......................................................................................................26
Trabalhando com Linhas e Colunas............................................................................................26
Inserindo e Excluindo Linhas e Colunas ..............................................................................26
Alterando a Altura e Largura de Linhas e Colunas ................................................................27
Formatando a Tabela ....................................................................................................................27
Seção Fonte ................................................................................................................................27
Seção Alinhamento ....................................................................................................................27
Seção Número ............................................................................................................................28
Inserindo e Excluindo Gráficos.....................................................................................................28
Banco de Dados e SQL ................................................................................................................. 30
Introdução...................................................................................................................................30
Banco de Dados ....................................................................................................................30
SGBD x GA ...........................................................................................................................32
Considerações Finais .............................................................................................................34
Características Gerais de um SGBD ......................................................................................34
Componentes de um Banco de Dados .......................................................................................36
Banco de Dados Relacional .......................................................................................................37
Relacionamentos entre Tabelas ............................................................................................38
Modelagem de Dados ..............................................................................................................41
Cardinalidade do Relacionamento ...........................................................................................43
SQL - Structured Query Language ...............................................................................................46
Introdução ..................................................................................................................................46
Parte I - Comandos de Modificação do Esquema e Criação de Banco de Dados .......................47
Comando Create ....................................................................................................................47
Comando Drop .......................................................................................................................49
Comando Alter .......................................................................................................................50
Prática ....................................................................................................................................50
Parte II - Comandos de Consulta ao Esquema .........................................................................51
Operadores Lógicos ................................................................................................................51
Demais Operadores ................................................................................................................54
Operadores Negativos ............................................................................................................54
Funções de Caracteres ............................................................................................................55
Funções Agregadas (ou de Agrupamento) .............................................................................56
2
Agrupamentos ........................................................................................................................56
Having ....................................................................................................................................57
Equi-Junção (Junção por igualdade) ......................................................................................58
As sub-consultas......................................................................................................................59
Uniões .....................................................................................................................................60
Inserções, Alterações e Exclusões ..........................................................................................60
Transações ..............................................................................................................................61
Visões .....................................................................................................................................62
3
Sistema operacional Microsoft Windows XP
Iniciando o Windows XP
O Windows XP é iniciado logo após o computador ter sido ligado, a primeira tela que
aparece então é a tela de logon, onde se seleciona o usuário que irá utilizar a máquina.
Quando o usuário é selecionado, através de um clique no botão correspondente, o sistema
operacional passa imediatamente para outra tela, chamada de área de trabalho:
4
Desligar o computador
Sempre que se utiliza o computador, deve-se adotar procedimentos corretos para o seu
desligamento, caso contrário danos poderão ocorrer, ou até perda de informações. Ao clicar no
botão iniciar, no canto inferior esquerdo da área de trabalho, aparecerão as opções: desligar e
fazer logoff.
Clicando em desligar, a figura acima aparece, e nela novas opções são mostradas:
- Em espera: salva no disco rígido todos os programas em execução e desliga o computador. Ao
religá-lo, serão exibidas exatamente as mesmas informações existentes no momento em que o
mesmo foi desligado;
- Desativar: desliga corretamente o computador;
- Reiniciar: desliga e imediatamente inicia novamente o sistema operacional.
A opção fazer logoff, apresentada na figura abaixo, proporciona a troca de usuário ou o
fechamento de todos os programas em execução sem, no entanto, desligar a máquina.
Área de trabalho
Na Área de Trabalho ou Desktop são exibidos janelas, ícones, menus e caixas de dialogo,
que são elementos básicos para se iniciar uma atividade dentro do Windows XP. Nela
encontram-se:
- Ícones
- Barra de tarefas
- Botão iniciar
5
ÍCONES ou Botões são figuras que representam recursos do computador, um ícone pode
representar um texto, música, programa, fotos, etc., e pode ser acionado por um clique de mouse.
Você pode adicionar ícones na Área de Trabalho, assim como pode excluir. Alguns ícones são
padrões do Windows, como Meu Computador, Meus Documentos, Meus locais de Rede, Internet
Explorer e Lixeira:
6
A Barra de tarefas é localizada na parte inferior da área de trabalho e nela se encontram o
Botão Iniciar, a Barra de Inicialização Rápida, a Barra de Ferramentas, a Barra de Idiomas e a
Área de Notificação. Você pode personalizar a barra de tarefas, ocultá-la e movê-la para os lados
ou para a parte superior da área de trabalho.
Barra de Ferramentas
O Botão Iniciar localiza-se no canto direito da Barra de tarefas e tem como função
acessar o Menu Iniciar após ser acionado por um clique do mouse.
Menu Iniciar
O Menu Iniciar surge quando damos um único clique sobre o botão Iniciar, apresentando
por sua vez, vários outros menus. Cada menu pode também ser subdividido em outros. No jargão
da informática a palavra Menu reporta à lista de opções ou entradas, postas à disposição do
usuário, que aparece no vídeo de um terminal de computador. Nesta lista estão contidas as
funções que o computador poderá realizar por meio de um programa.
7
Na figura acima destacam-se os seguintes subitens:
- Meus Documentos: abre a pasta “meus documentos” onde você pode armazenar cartas,
relatórios, anotações, planilhas, e outros tipos de documentos.
- Documentos Recentes: exibe documentos que foram anteriormente abertos pelo usuário.
- Minhas Imagens: abre a pasta “Minhas imagens”, onde é possível armazenar fotos digitais,
imagens e arquivos gráficos.
- Minhas Músicas: abre a pasta “Minhas músicas” onde é possível armazenar músicas e outros
arquivos de áudio.
- Meu Computador: fornece acesso e informações sobre unidades de disco, câmaras, scanners e
outros itens de hardware conectado ao computador.
- Painel de Controle: Acessa o Painel de Configurações do Windows.
- Definir Acesso e Padrões do Programa: personaliza programas padrões para certas
atividades, tais como, navegar pela Web ou enviar e-mail.
- Conectar-se: oferece um atalho para conectar-se a um provedor.
- Impressoras e Aparelhos de Fax: mostra impressoras, impressoras de fax instaladas, e ajuda a
instalar novas impressoras.
- Ajuda e Suporte: oferece ajuda e informações sobre o Windows.
- Pesquisar: Localiza arquivos no sistema ou, se estiver conectado em rede, localiza outros
computadores na sua organização, ou na Internet.
- Executar...: executa um programa, um arquivo, uma pasta, etc.
8
Menu todos os programas
Um Programa, que é o mesmo que Software ou Aplicativo, compreende um conjunto de
instruções de computador e é utilizado para a realização de uma tarefa específica, como por
exemplo, a digitação de um trabalho escolar. Ao clicar com o mouse em Todos os Programas,
no menu Iniciar, é aberta uma lista dos programas instalados no computador que são básicos do
Windows XP.
Para acessar o menu Todos os programas, clique no menu Iniciar e arraste o mouse em
linha reta para a direção em que este menu foi aberto, assim, é possível selecionar qualquer
programa desse menu ou um de seus subitens.
Abrindo programas
Os próximos passos demonstrarão como se abre um programa do pacote Microsoft
Office:
a) Clique sobre o menu Iniciar;
b) Direcione o ponteiro do mouse para a guia Todos os programas;
c) Aberto o menu Todos os programas, arraste o mouse através deste até que se destaque a
opção Microsoft Office;
d) Um novo menu se apresentará, nele clique com o mouse sobre o programa Microsoft Office
Word.
9
Desta forma, o programa Microsoft Word será aberto em uma nova janela:
Outra forma de se executar programas é a utilização do comando Executar, conforme
descrevem os passos a seguir;
- Clique no Botão Iniciar, depois, clique na opção Executar do menu Iniciar;
- Abre-se a caixa de diálogo do comando Executar, onde aparece um cursor intermitente no
campo Abrir;
10
- Digite no campo Abrir o nome do programa ou arquivo que deseja executar e, em seguida,
clique no botão OK, ou pressione a tecla Enter no teclado;
- Se preferir, clique em Procurar nesta mesma caixa de diálogo e procure o arquivo, pasta ou
programa que deseja abrir.
Finalmente, um programa também pode ser executado através da utilização de atalhos.
Um atalho é a referencia dada à via de entrada mais rápida em um sistema, um programa, uma
pasta, uma unidade de disco, uma página na Web etc. No sistema Windows pode ser feito pelo
teclado ou por ícones. Você pode colocar atalhos em vários locais, como na área de trabalho, no
menu Iniciar ou em pastas específicas. Exemplos de atalhos:
Observação: Quando um programa é aberto, o Windows o exibe, automaticamente no menu
Iniciar e um botão representando esse programa será exibido na Barra de tarefas.
Janelas
Janela é o trecho retangular da tela do computador no qual um documento, arquivo, mensagem,
imagem etc., é exibido por um programa ou sistema operacional.
11
A Barra de Título é a barra horizontal na parte superior de uma janela que contém:
a) o símbolo que representa o respectivo programa;
b) o título (nome) do documento ativo;
c) o título do aplicativo que está sendo executado na janela;
d) e os botões Minimizar, Restaurar/Maximinar e Fechar.
A Barra de Menu (ilustração abaixo) é a barra horizontal na parte superior da tela, abaixo da
Barra de Título, que contém uma série de opções à escolha do usuário, dispostas em seqüência e
indicadas por palavras.
Se o arquivo que estiver sendo criado ou modificado dentro da janela não foi salvo antes de
fechar o aplicativo, o Windows emitirá uma tela de alerta perguntando se queremos ou não
*salvar o arquivo, ou cancelar a operação antes de sair do aplicativo.
Salvar é o mesmo que gravar, isto é, transferir dados digitalizados para um meio de
armazenamento (CDs, disquetes, HD, Pen drive, etc.) de modo a poder recuperá-los
posteriormente.
Exercícios
Minimizar/ restaurar/ maximizar uma janela:
a) Abra o Microsoft Word,
b) Clique sobre o botão em para reduzir a janela a um botão da Barra de Tarefas;
c) Clique no ícone na Barra de Tarefas para restaurar a janela minimizada ao tamanho anterior;
d) Com a janela ocupando toda a tela, clique em para reduzi-la a um tamanho menor, de maneira
que poderá ser visualizada na Área de Trabalho;
e) Com a janela reduzida a um tamanho menor na Área de Trabalho, clique sobre o botão para
maximizar a janela de forma que se estenda à tela inteira.
f) Clique duas vezes na Barra de Título da janela para restaurar a janela a um tamanho menor e
ser visualizada na Área de Trabalho ou maximizá-la ao tamanho anterior.
Alternar entre programas:
1. Abra o aplicativo Paint e o Bloco de Notas;
2. Alterne entre estes dois programas clicando hora no ícone do aplicativo Paint, hora no ícone
do aplicativo Bloco de Notas na Barra de Tarefas e veja o resultado.
Reduzindo as janelas abertas a botões da Barra de Tarefas:
1. Abra as janelas dos respectivos aplicativos e objetos:
a) Bloco de Notas,
b) Paint,
c) Word,
12
d) Excel
e) Meu Computador;
f) Lixeira.
2. Mantenha todas as janelas acima maximizadas;
3. Clique no botão na Barra de Inicialização rápida que se localiza no canto esquerdo da Barra
de Tarefas para reduzir todas as janelas abertas a um botão da Barra de Tarefas.
4. Clique novamente no botão na Barra de Inicialização rápida para restaurar todas as janelas
ao tamanho anterior.
Trabalhando com múltiplas janelas
O Microsoft Windows XP permite executar mais de um aplicativo ao mesmo tempo e
cada aplicativo suporta várias janelas de documento. Por exemplo, um usuário pode trabalhar
com vários documentos do Microsoft Word ou outros aplicativos enquanto navega na internet,
usa a impressora ou ouve uma música.
13
Quando tarefas simultâneas estão sendo conduzidas no computador, uma janela é aberta
para cada uma das atividades. Várias janelas abertas ao mesmo tempo podem causar desordem
na Área de Trabalho. Uma forma de se trabalhar de modo organizado é manter uma única janela
maximizada por vez, e as demais reduzidas a um botão da Barra de Tarefas, isto é, minimizadas.
Organizando a área de trabalho
Quando for necessário trabalhar visualizando o conteúdo de diversos aplicativos ao
mesmo tempo, pode-se organizar as janelas dos respectivos programas de muitas formas,
viabilizando a cópia do conteúdo de uma janela para outra ou a realização de outras atividades.
Para arrumarmos as janelas na Área de Trabalho, pode-se arranjá-las manualmente ou se utilizar
do comando que o Windows dispõe para esta tarefa:
- Para mover uma janela manualmente, deve-se manter o botão esquerdo do mouse pressionado
sobre a barra de títulos, arrastando-a para a posição desejada;
- Para dispor as janelas abertas em uma organização específica, utilizando o comando do
Windows, siga o exemplo:
· Abra os programas Paint e WordPad que estão na pasta Acessórios;
· Abertos estes programas, clique com o botão direito do mouse sobre uma área vazia da Barra
de Tarefas;
· Escola a opção desejada: Janelas em cascata, Janelas lado a lado horizontalmente ou
Janelas lado a lado verticalmente.
Para restaurar as janelas ao estado anterior, clique com o botão direito do mouse em uma
área vazia da Barra de Tarefas e, em seguida, clique em “Desfazer Em Cascata” ou “Desfazer
Lado a lado”. Também é possível alterar o tamanho das janelas, posicionando-se o mouse em
uma de suas bordas e, mantendo o botão esquerdo pressionado, arrastando-o até que a janela
fique do tamanho desejado.
14
Organizando Ícones na área de trabalho
Para organizar os ícones da área de trabalho, deve-se posicionar o mouse em uma parte
vazia da mesma e clicar com o seu botão direito, o que fará surgir uma janela de menu.
Selecionando-se a opção Organizar ícones, serão encontradas algumas opções de organização
que podem ser selecionadas conforme a conveniência do usuário.
15
Planilha de Cálculo Microsoft Microsoft Office Excel
PARA EXECUTAR O MICROSOFT OFFICE EXCEL
clique em Iniciar _Todos os programas _ Microsoft Office _ Microsoft Office Excel.
INICIANDO O DOCUMENTO
Quando você cria uma planilha nova, a tela do computador é dividida em linhas e
colunas, formando uma grade. A interseção de uma linha e de uma coluna é chamada
de célula. As linhas são numeradas seqüencialmente, as colunas. são identificadas por
letras também seqüenciais e cada célula pela linha e
coluna que a forma.
Uma célula pode conter números, texto ou fórmulas. Por exemplo, a célula A4 (na tela
abaixo) contém o valor 10 e a célula D2 contém o texto “Valor total”.
Em geral, informações da mesma categoria são digitadas em uma coluna (no exemplo,
a coluna B é a descrição do produto vendido; a coluna C é o valor unitário), mas essa
16
estrutura não é rígida: você pode agrupar as informações por linha ou por outras
formas mais convenientes para o seu caso.
A possibilidade de usar fórmulas é o que diferencia um programa de planilha de uma
calculadora. Quando colocamos uma fórmula em uma célula, dizemos que o conteúdo
dessa célula deve ser calculado em função dos valores contidos em outras células.
Na planilha abaixo, o preço total de uma venda é calculado multiplicando- se o preço
unitário pela quantidade vendida de produtos do mesmo tipo. Em nosso exemplo, a
coluna A registra a quantidade de produtos e a coluna C traz o preço unitário do
produto. A coluna D mostra o preço total. O conteúdo de cada célula é calculado
multiplicando-se os valores da coluna A pelos valores da coluna C. Para que esse
cálculo seja feito automaticamente, devemos digitar a fórmula =A4*C4 na célula D4.
Quando modificamos o valor de A4, o valor de D4 é recalculado automaticamente de
acordo com a fórmula registrada na célula.
Normalmente, uma planilha é criada em duas etapas. Primeiro você determina os itens
que deseja calcular e as fórmulas a serem usadas para fazer esse cálculo. Depois, na
fase de utilização da planilha, é preciso digitar os valores correspondentes a cada item;
os resultados serão calculados automaticamente.
Aqui mostraremos como criar uma planilha, usando o programa Microsoft Office Excel,
mas o procedimento descrito aplica-se a qualquer programa
de planilha. Como exemplo, vamos fazer uma planilha para controlar o faturamento de
uma empresa que vende apenas quatro produtos. Embora as fórmulas sejam
diferentes para cada planilha, o procedimento será sempre o
mesmo.
17
Quando abrimos o Microsoft Office Excel, já aparece um desenho básico de planilha na
tela. Precisamos, então, organizar as informações em linhas e colunas e determinar
uma região para cada tipo de informação. No layout, apenas definimos onde cada
informação será colocada, mas ainda não a digitamos. No nosso exemplo, vamos
registrar o faturamento de cada um dos quatro produtos, mês a mês. A partir dessas
informações, calcularemos:
_ O faturamento mensal de cada produto.
_ O faturamento anual de cada produto.
A planilha tem espaços reservados tanto para as informações que serão digitadas
quanto para as que serão calculadas automaticamente.
As informações serão digitadas da célula B4 até a célula E15. Por exemplo, na célula
B4 digitaremos o faturamento do mês de janeiro correspondente a engrenagens; na
célula C4, o faturamento de janeiro de parafusos; na célula B5, o faturamento de
fevereiro de engrenagens, e assim por diante, até o faturamento de dezembro de
arruelas na célula E15.
As informações da coluna F, sobre faturamento mensal total, e as informações
da linha 17, sobre o faturamento anual por produto, serão calculadas automaticamente.
18
Primeiro, vamos escrever as fórmulas para calcular o faturamento total mensal (coluna
F). Esse faturamento é a soma dos valores vendidos de cada produto.
Assim, o faturamento total de janeiro (célula F4) será a soma do faturamento de cada
produto nesse mês (da célula B4 até a E4). Portanto, na célula F4 digitaremos a
seguinte fórmula:
Célula Fórmula
Célula Fórmula
F4 =B4+C4+D4+E4
Isso indica para o programa de planilha que o valor de F4 será a soma dos valores das
células B4, C4, D4 e E4.
19
A fórmula da célula F5 é muito parecida com a fórmula da célula F4 e o
mesmo acontece com todas as células, até F15.
Célula Fórmula
F4 =B4+C4+D4+E4
F5 =B5+C5+D5+E5
F6 =B6+C6+D6+E6
F7 =B7+C7+D7+E7
F8 =B8+C8+D8+E8
F9 =B9+C9+D9+E9
F10 =B10+C10+D10+E10
F11 =B11+C11+D11+E11
F12 =B12+C12+D12+E12
F13 =B13+C13+D13+E13
F14 =B14+C14+D14+E14
20
F15 =B15+C15+D15+E15
Como seria bastante trabalhoso digitar essa mesma fórmula 12 vezes, vamos copiá-la.
Posicione o cursor sobre a célula F4.
Abra a guia Início e escolha o comando Copiar (CTRL + C); o computador
copiará o conteúdo de F4.
Selecione da célula F5 à F15. Para isso, clique sobre a célula F5 e, mantendo
o botão do mouse pressionado, arraste-o até a célula F15.
Pressione a tecla ENTER.
O programa percebe que a fórmula mudou de linha e altera o seu conteúdo: em vez de
copiar =B4+C4+D4+E4 para todas as linhas, ele adequará a fórmula para cada linha.
Assim, na célula F5 será escrito =B5+C5+D5+E5; na célula F6, =B6+C6+D6+E6 e
assim por diante.
O procedimento para calcular o faturamento anual de cada produto é bastante parecido
com o anterior: o faturamento anual de engrenagens é a soma do seu faturamento em
cada mês. Na célula B17, poderíamos digitar a seguinte fórmula:
Célula Fórmula
B17 =B4+B5+B6+B7+B8+B9+B10+B11+B12+B13+B14+B15
21
Quando a fórmula for muito grande, usaremos a função SOMA do Microsoft
Office Excel, que facilita o cálculo, somando todas as células especificadas.
Na célula B17, a fórmula será:
Célula Fórmula
B17 =Soma(B4:B15)
A notação B4:B15 indica que devem ser utilizadas todas as células no intervalo de B4
até B15. Assim, essa fórmula irá somar os valores em todas essas células e exibir o
resultado na célula B17.
22
Agora, precisamos copiar essa fórmula para as células de C17, D17 e E17. Podemos
usar o mesmo procedimento que foi descrito acima. O programa perceberá que elas
foram
colocadas
em
outra
coluna
e
ajustará
as
referências
das
colunas
automaticamente. Assim, após copiar a fórmula para a coluna C17, teremos
=Soma(C4:C15); na célula D17 aparecerá =Soma(D4:D15), e assim por diante.
Agora, nossa planilha está completa e basta digitar os valores unitários relativos a cada
mês e a cada tipo de produto, das linhas 4 a 15, das colunas B
a E. O programa nos dará, automaticamente, os valores da linha 17 e da coluna F.
A rapidez é uma das grandes vantagens dos programas de planilha. Se você cometer
um erro ou quiser modificar o valor de uma célula, basta digitar o valor correto e todos
os outros valores serão atualizados automaticamente. Funções de uma planilha são
comandos mais compactos e rápidos para se executar fórmulas. Com elas é possível
fazer operações complexas com uma única fórmula. As funções são agrupadas em
categorias, para ficar mais fácil a sua localização. As funções também facilitam o
trabalho com planilhas especializadas.
23
Um engenheiro pode utilizar funções matemáticas para calcular a resistência de um
material. Um contador usará funções financeiras para elaborar o balanço de uma
empresa. Entre as diversas funções, destacam-se:
Funções financeiras - Para calcular juros, rendimento de aplicações, depreciação de
ativos etc.
Funções matemáticas e trigonométricas - Permite calcular raiz quadrada, fatorial,
seno, tangente etc.
Funções estatísticas - Para calcular a média de valores, valores máximos e mínimos
de uma lista, desvio padrão, distribuições etc.
Funções lógicas - Possibilitam comparar células e apresentar valores que não podem
ser calculados com fórmulas tradicionais.
A escolha de um ou outro tipo de função depende do objetivo da planilha. Por isso, a
Ajuda do programa de planilha é um valioso aliado. Ela contém a lista de todas as
funções do programa, normalmente com exemplo. Para ilustrar, usaremos a função
estatística MÉDIA e a função lógica SE em uma planilha que controla a nota dos
alunos de uma escola. Se a média for superior a 5, o aluno é aprovado; caso contrário,
é reprovado.
Na tela abaixo, as notas foram digitadas nas colunas de B até E e suas médias
colocadas na coluna F, com o auxílio da função MÉDIA. Essa função calcula a média
das células indicadas. Para aplicá-la:
Digite a fórmula =Média(B3:E3) na célula F3. Ela indica o próximo passo a ser dado: o
cálculo da média das células de B3 a E3 (a média de B3, C3, D3
24
e E3).
Célula Fórmula
F3 =Média(B3:E3)
Para que o programa indique se um aluno foi aprovado ou não, a média obtida por
esse aluno deve ser comparada com 5. Isso é feito digitando-se a fórmula
=Se(F3<5;”Reprovado”;”Aprovado”) na célula G3.
O conteúdo da célula G3 é determinado pela condição de teste F3<5. Ela exibirá o
“Reprovado” caso a condição F3<5 seja verdadeira, ou seja, se o aluno obtiver média
inferior a 5. Mostrará o valor “Aprovado” no caso de a condição F3<5 ser falsa, ou
seja, se o aluno obtiver uma média igual ou maior
que 5.
Célula Fórmula
G3 =Se(F3<5;”Reprovado”;”Aprovado”)
25
INSERINDO E EXCLUINDO PLANILHAS
Uma pasta de trabalho padrão apresenta, inicialmente, 3 planilhas. Caso necessite de
mais planilhas, você pode incluí-las, utilizando o seguinte comando:
Inserir Planilha (SHIFT + F11).
Uma pasta de trabalho padrão apresenta, inicialmente, 3 planilhas. Caso não necessite
de todas, você pode excluir as desnecessárias, selecionando-as e utilizando os
comandos: Clique com o botão direito do mouse sobre a planilha
e clique na opção Excluir.
26
RENOMEANDO PLANILHAS
No Microsoft Office Excel, um arquivo, ou seja, uma pasta, pode conter várias planilhas
diferentes, sendo, portanto, fundamental nomeá-las de maneira a distingui-las. A
nomeação não grava a planilha, por isso é necessário utilizar o comando Salvar (CTRL
+ B).
Para nomear a planilha, utilize um dos seguintes comandos: Clique duplamente
na guia da planilha que deseja renomear.
Digite o nome da planilha e pressione a tecla ENTER.
TRABALHANDO COM LINHAS E COLUNAS
INSERINDO E EXCLUINDO LINHAS E COLUNAS
Imagine que, durante a digitação de uma seqüência de dados, alguns dados foram
esquecidos, ficando a tabela incompleta. Os dados podem ser introduzidos
posteriormente nos locais corretos, bastando para isso fazer a escolha adequada entre
as opções de inserção, encontradas na guia Início: Selecione o local adequado e
clique na ferramenta Inserir, Inserir Linhas na Planilha ou Inserir Colunas na
Planilha.
27
De modo semelhante é possível fazer a exclusão de colunas ou linhas que tenham sido
introduzidas equivocadamente ou que não sejam mais necessárias.
O comando de exclusão de linhas ou colunas pode ser encontrado na guia Início, na
ferramenta Excluir, Excluir Linhas da Planilha ou Excluir Colunas da Planilha.
ALTERANDO A ALTURA E LARGURA DE LINHAS E COLUNAS
A definição de tamanho é extremamente comum para as linhas e colunas. Para alterar
a altura de uma linha ou largura de uma coluna, faça o seguinte: aponte o mouse entre
as linhas 1 e 2, clique e arraste para alterar a altura da linha ou aponte o mouse entre
as colunas A e B, clique e arraste para alterar a largura da coluna.
FORMATANDO A TABELA
Seção Fonte
Você pode mudar o visual das letras, números ou outros caracteres digitados
das células selecionadas.
Seção Alinhamento
Você pode modificar o alinhamento das letras, números ou outros caracteres digitados
das células selecionadas.
28
Seção Número
Você pode formatar os números das células selecionadas.
INSERINDO E EXCLUINDO GRÁFICOS
Para inserir um gráfico, selecione a área com os dados que deseja apresentar nele.
Selecione, inclusive, os dados que serão apresentados como legenda e como gráfico.
Lembrasse: antes de fazer qualquer tipo de gráfico é necessário selecionar pelo
menos um grupo de textos para servir como legenda e um ou mais grupos de números
para servir como gráfico.
Selecione os meses que vão servir como legenda, mantenha a tecla CTRL pressionada
e selecione os valores que vão servir como gráficos, clique na guia Inserir e escolha
um modelo de gráfico mais adequado
29
Para apagar um gráfico selecionado, tecle DELETE.
LEMBRETE:
Nas formulas usamos os operadores (+ - * /)
Nas funções, escrevemos as operações (soma, máximo, mínimo, media, se)
Toda formula ou função começa a ser escrita com o sinal (=)
30
Banco de Dados e SQL
Introdução
Devido à carência de literatura destinada ao ensino de Banco de Dados e SQL para
estudantes, elaboramos a presente apostila, que não possui o intento de esgotar tão
abrangente volume de informações, servindo tão somente para estabelecer um mínimo
de conhecimentos destinados a introduzir o estudante no mundo dos Gerenciadores de
Banco de dados e da Linguagem SQL.
Banco de Dados
Todos nós sabemos existirem gigantescas bases de dados gerenciando nossas vidas.
De fato sabemos que nossa conta bancária faz parte de uma coleção imensa de contas
bancárias de nosso banco. Nosso Título Eleitoral ou nosso Cadastro de Pessoa Física,
certamente estão armazenados em Bancos de Dados colossais. Sabemos também que
quando sacamos dinheiro no Caixa Eletrônico de nosso banco, nosso saldo e as
movimentações existentes em nossa conta bancária já estão à nossa disposição.
Nestas situações sabemos que existe uma necessidade em se realizar
o
armazenamento de uma série de informações que não se encontram efetivamente
isoladas umas das outras, ou seja, existe uma ampla gama de dados que se referem a
relacionamentos existentes entre as informações a serem manipuladas.
Estes Bancos de Dados, além de manterem todo este volume de dados organizado,
também devem permitir atualizações, inclusões e exclusões do volume de dados, sem
nunca perder a consistência. E não podemos esquecer que na maioria das vezes
estaremos lidando com acessos concorrentes a várias tabelas de nosso
banco de dados, algumas vezes com mais de um acesso ao mesmo registro de uma
mesma tabela!
O fato de montarmos uma Mala Direta em um micro PC-XT com um drive já faz de nós
um autor de um Banco de Dados?
Claro que não! Um Banco de Dados é antes de mais nada uma coleção logicamente
coerente de dados com determinada significação intrínseca. Em outras palavras um
arquivo contendo uma série de dados de um cliente, um arquivo com dados
aleatoriamente gerados e dois arquivos padrão dbf (dBase) que tem uma relação
definida entre ambos, não pode ser considerada uma Base de Dados Real.
Um Banco de Dados contém os dados dispostos numa ordem pré-determinada em
função de um projeto de sistema, sempre para um propósito muito bem definido.
Um Banco de Dados representará sempre aspectos do Mundo Real. Assim sendo uma
Base de Dados (ou Banco de Dados, ou ainda BD) é uma fonte de onde poderemos
extrair uma vasta gama de informações derivadas, que possui um nível de interação
com eventos como o Mundo Real que representa. A forma mais comum de interação
31
Usuário e Banco de Dados, dá-se através de sistemas específicos que por sua vez
acessam o volume de informações geralmente através da linguagem SQL.
Os Administradores de Banco de Dados (DBA) são responsáveis pelo controle ao
acesso aos dados e pela coordenação da utilização do BD. Já os projetistas de Banco
de Dados (DBP) são analistas que identificam os dados a serem armazenados em um
Banco de Dados e pela forma como estes serão representados.
Os Analistas e Programadores de Desenvolvimento, criam sistemas que acessam os
dados da forma necessária ao Usuário Final, que é aquele que interage diretamente
com o Banco de Dados.
SGBD x GA
Um SGBD - Sistema de Gerenciamento de Banco de Dados é uma coleção de
programas que permitem ao usuário definir, construir e manipular Bases de Dados para
as mais diversas finalidades.
Um conceito que deverá ficar bastante claro inicialmente é o que envolve a separação
clara entre os Gerenciadores de Base de Dados dos Gerenciadores de Arquivo.
Sistemas baseados em "Banco de Dados" baseados em Btrieve e dBase (Fox e
Clipper), podem no máximo simular as características típicas de um ambiente de Banco
de Dados. As linguagens Delphi (utiliza opcionalmente o padrão dBase) e o VB (que
utiliza o Access), recomendam a utilização de Banco de Dados reais, porém utilizam
àqueles "Banco de Dados" que possuem algumas características de Bancos de Dados,
mas possuem características típicas de Gerenciadores de Arquivo.
Vamos definir algumas regras básicas e claras para um sistema de manipulação de
dados ser considerado um SGBD. Fica implícito que se ao menos uma das
características abaixo não estiver presente no nosso "candidato" a SGBD, este poderá
ser um GA (Gerenciador de Arquivo) de altíssima qualidade, "quase" um
SGBD, mas não um SGBD.
Regra 1: Auto-Contenção- Um SGBD não contém apenas os dados em si, mas
armazena completamente toda a descrição dos dados, seus relacionamentos e formas
de acesso. Normalmente esta regra é chamada de Meta-Base de Dados. Em um GA,
em algum momento ao menos, os programas aplicativos declaram estruturas (algo que
ocorre tipicamente em C, COBOL e BASIC), ou geram os relacionamentos entre os
arquivos (típicos do ambiente xBase). Por exemplo, quando você é obrigado a definir a
forma do registro em seu programa, você não está lidando com um SGBD.
Regra 2: Independência dos Dados- Quando as aplicações estiverem realmente
imunes a mudanças na estrutura de armazenamento ou na estratégia de acesso aos
dados, podemos dizer que esta regra foi atingida. Portanto, nenhuma definição dos
dados deverá estar contida nos programas da aplicação. Quando você resolve criar
uma nova forma de acesso, um novo índice, se precisar alterar o código de seu
aplicativo, você não está lidando com um SGBD.
32
Regra 3: Abstração dos Dados - Em um SGBD real é fornecida ao usuário somente
uma representação conceitual dos dados, o que não inclui maiores detalhes sobre sua
forma de armazenamento real. O chamado Modelo de Dados é um tipo de abstração
utilizada para fornecer esta representação conceitual. Neste modelo, um esquema das
tabelas, seus relacionamentos e suas chaves de acesso são exibidas ao usuário,
porém nada é afirmado sobre a criação dos índices, ou como serão mantidos, ou qual a
relação existente entre as tabelas que deverá ser mantida íntegra. Assim se você
desejar inserir um pedido em um cliente inexistente e esta entrada não for
automaticamente rejeitada, você não está lidando com um SGBD.
Regra 4: Visões- Um SGBD deve permitir que cada usuário visualize os dados de
forma diferente daquela existente previamente no Banco de Dados. Uma visão consiste
de um subconjunto de dados do Banco de Dados, necessariamente derivados dos
existentes no Banco de Dados, porém estes não deverão estar
explicitamente armazenados. Portanto, toda vez que você é obrigado a replicar uma
estrutura, para fins de acesso de forma diferenciada por outros aplicativos, você não
está lidando com um SGBD.
Regra 5: Transações - Um SGBD deve gerenciar completamente a integridade
referencial definida em seu esquema, sem precisar em tempo algum, do auxílio do
programa aplicativo. Desta forma exige-se que o banco de dados tenha ao menos uma
instrução que permita a gravação de uma série modificações simultâneas e uma
instrução capaz de cancelar um série modificações. Por exemplo, imaginemos que
estejamos cadastrando um pedido para um cliente, que este deseje reservar 5 itens de
nosso estoque, que estão disponíveis e portanto são reservados, porém existe um
bloqueio financeiro (duplicatas em atraso) que impede a venda. A transação deverá ser
desfeita com apenas uma instrução ao Banco de Dados, sem qualquer modificações
suplementares nos dados. Caso você se obrigue a corrigir as reservas, através de
acessos complementares, você não está lidando com um SGBD.
Regra 6: Acesso Automático - Em um GA uma situação típica é o chamado DeadLock, o abraço mortal. Esta situação indesejável pode ocorrer toda vez que um usuário
travou um registro em uma tabela e seu próximo passo será travar um registro em uma
tabela relacionada à primeira, porém se este registro estiver previamente travado por
outro usuário, o primeiro usuário ficará paralisado, pois, estará esperando o segundo
usuário liberar o registro em uso, para que então possa travá-lo e prosseguir sua tarefa.
Se por hipótese o segundo usuário necessitar travar o registro travado pelo primeiro
usuário (!), afirmamos que ocorreu um abraço mortal, pois cada usuário travou um
registro e precisa travar um outro, justamente o registro anteriormente travado pelo
outro! Imaginemos um caso onde o responsável pelos pedidos acabou de travar o
Registro Item de Pedido, e, necessita travar um registro no Cadastro de Produtos, para
indicar uma nova reserva. Se concomitantemente estiver sendo realizada uma tarefa
de atualização de pendências na Tabela de Itens, e para tanto, previamente este
segundo usuário travou a Tabela de Produtos, temos a ocorrência do abraço mortal. Se
a responsabilidade de evitar esta ocorrência for responsabilidade da aplicação, você
não está lidando com um SGBD.
Conclusão: Um SGBD deve obedecer INTEGRALMENTE as seis regras acima. Em
caso contrário estaremos diante de um GA ou de um "quase" SGBD.
33
Considerações Finais
Atualmente, existe uma tendência de mercado em se dizer que qualquer problema será
resolvido, caso a empresa adquira um Banco de Dados. Naturalmente, em um
ambiente com acesso constante ao Banco de Dados (acesso concorrente,
obviamente), onde a segurança seja de vital importância e que o desempenho da
aplicação escrita estiver comprometendo a empresa, considerando-se logicamente
uma aplicação bem escrita, sem dúvida a aquisição de um Banco de Dados poderá ser
o primeiro passo na solução do problema.
Analogamente ao que ocorreu com o aparecimento das primeiras linguagens de
programação voltadas ao Windows, onde estas foram apresentadas como capazes de
alavancar os negócios da empresa, e no geral causaram mais frustração do que
solução, a aquisição do Banco de Dados, pode gerar o mesmo tipo de problema.
É fundamental que a empresa candidata a utilizar um Banco de Dados, normatize
totalmente, pois soluções “quebra-galho”, típicas do ambiente que dispõe de um
Gerenciador de Arquivo, tendem a ser impossíveis em um ambiente estruturado sobre
o Banco de Dados. Portanto, sob pena de se realizar um grande investimento, e não se
colher fruto algum, é muito conveniente, que a empresa antes de adquirir um Banco de
Dados, passe por um processo de adaptação, preferencialmente contando com
pessoal especializado, geralmente consultores, que não tenham qualquer ligação com
fabricantes de Bancos de Dados.
Características Gerais de um SGBD
Os SGBD tem sete características operacionais elementares sempre observadas, que
passaremos a listar:
Característica 1: Controle de Redundâncias - A redundância consiste no
armazenamento de uma mesma informação em locais diferentes, provocando
inconsistências. Em um Banco de Dados as informações só se encontram
armazenadas em um único local, não existindo duplicação descontrolada dos dados.
Quando existem replicações dos dados, estas são decorrentes do processo de
armazenagem típica do ambiente Cliente-Servidor, totalmente sob controle do Banco
de Dados.
Característica 2: Compartilhamento dos Dados - O SGBD deve incluir software de
controle de concorrência ao acesso dos dados, garantindo em qualquer tipo de
situação a escrita/leitura de dados sem erros.
Característica 3: Controle de Acesso - O SGDB deve dispor de recursos que
possibilitem selecionar a autoridade de cada usuário. Assim um usuário poderá realizar
qualquer tipo de acesso, outros poderão ler alguns dados e atualizar outros e outros
ainda poderão somente acessar um conjunto restrito de dados para escrita e leitura.
Característica 4: Interfaceamento - Um Banco de Dados deverá disponibilizar formas
de acesso gráfico, em linguagem natural, em SQL ou ainda via menus de acesso, não
sendo uma "caixa-preta" somente sendo passível de ser acessada por aplicações.
34
Característica 5: Esquematização - Um Banco de Dados deverá fornecer
mecanismos que possibilitem a compreensão do relacionamento existentes entre as
tabelas e de sua eventual manutenção.
Característica 6: Controle de Integridade - Um Banco de Dados deverá impedir que
aplicações ou acessos pelas interfaces possam comprometer a integridade dos dados.
Característica 7: Backups - O SGBD deverá apresentar facilidade para recuperar
falhas de hardware e software, através da existência de arquivos de "pré-imagem" ou
de outros recursos automáticos, exigindo minimamente a intervenção de pessoal
técnico.
Existe a possibilidade de encontramos Bancos de Dados que não satisfaçam
completamente todas as características acima, o que não o inválida como Banco de
Dados. Na prática podemos encontrar situações onde a primeira característica não
seja importante, pois podemos ter o Banco de Dados baseado totalmente em um único
servidor, e as redundâncias podem ser aceitas em algumas situações sob controle da
aplicação (algo não muito recomendado, mas passível de aceitação, em situações
onde a existência do nome do cliente em um arquivo contendo duplicatas emitidas,
possibilita o acesso a apenas uma tabela sem relacionamentos, e sabe-se de antemão
que uma duplicata depois de emitida, não pode ter seu cliente alterado).
A segunda característica (Compartilhamento dos Dados) pode ser desconsiderada
principalmente em ambiente de desenvolvimento, ou ainda em aplicações remotas.
O Controle de Acesso pode ser descartado em pequenas empresas, sendo que o
aplicativo em questão, mais o software de rede, podem facilmente se incumbir desta
característica, no caso de pequenas empresas, com reduzido número de pessoas na
área operacional.
O Interfaceamento e a Esquematização são características sempre disponíveis, o que
varia neste caso é qualidade destes componentes, que vai desde o sofrível até o
estado da arte. É muito conveniente que esta característica seja muito boa em um
Banco de Dados, onde estiverem em atuação mais de um Administrador de Banco de
Dados e tivermos um número relativamente alto de sistemas desenvolvidos ou em
desenvolvimento neste ambiente.
De fato, quanto maior o número de pessoas envolvidas no desenvolvimento de
aplicações e gerenciamento do Banco de Dados, mais importante tornam-se estas
duas características, pois cada novo sistema desenvolvido precisará sempre estar
adequado ao Banco de Dados da Empresa e aderente aos padrões de acesso
utilizados nos sistemas concorrentes.
As interfaces ISQL e WinSQL devem deixar muito claro ao estudante como uma
interface pobre (no caso a existente no ISQL) perde muito, quando comparada a uma
interface mais recursiva. A esquematização existente no Banco de Dados é muito
melhor do que aquela mantida em alguma pasta, em algum arquivo do CPD, que
sempre está “um pouquinho” desatualizada.
O Controle de Integridade, é outra característica sempre presente nos Bancos de
Dados, mas existem diferenças quando da implementação desta característica. Assim,
35
é comum encontrarmos Bancos de Dados que suportam determinado acesso,
enquanto outros não dispõe de recurso equivalente.
O Backup em tempo de execução, é outra característica sempre disponível, porém
temos aplicações que invariavelmente são comprometidas por falhas de hardware, e
outras, que o mesmo tipo de falha não causa perda alguma de dados ou de
integridade. Novamente, cada Banco de Dados tem esta característica melhor ou pior
implementada, cabendo ao Administrador de Banco de Dados escolher aquele que lhe
oferecer mais segurança.
Devemos ressaltar ainda, que podemos ter um Banco de Dados Modelo A, que
respeite integralmente as regras básicas e disponha de todas as características
apresentadas, enquanto um Modelo B que apesar de respeitar as regras básicas, não
suporte uma ou outra característica desejável, mas tenha um desempenho excelente,
enquanto o Modelo A seja apenas razoável no quesito desempenho, nos levará
seguramente a escolher o Modelo B como sendo o ganhador para nossa instalação!
Isto ocorre pois, na prática, todo usuário deseja um tempo de resposta muito pequeno.
O chamado “prazo de entrega” muito comum em Bancos de Dados operando nos
limites de sua capacidade, ou nos casos onde o hardware está muito desatualizado, é
fonte de inúmeros problemas para o pessoal de informática. Neste caso é melhor
abrirmos mão de uma Interface Amigável, de um Gerenciamento Automático de
Backups ou ainda de outras características que não julgarmos fundamentais, para nos
livrarmos do problema típico de ambiente extremamente comprometido, por má
performance do Banco de Dados.
A escolha do Banco de Dados da empresa, portanto é uma decisão muito delicada, na
medida em que está irá acarretar troca de aplicativos e troca de hardware. Os
investimentos diretamente aplicados no Banco de Dados, costumam ser infinitamente
menores do que aqueles a serem aplicados na empresa, visando sua perfeita
adequação ao novo SGBD. Esta decisão, sempre que possível, deve ser tomada por
especialistas em Banco de Dados, com profundos conhecimentos de Análise de
Sistemas, de Banco de Dados e de Software de Gerenciamento de Bases de Dados,
de forma a evitar que a empresa escolha um Banco de Dados inadequado aos seus
propósitos, e que pouco tempo depois, seja obrigada a perder todos investimento
realizado em Software e Hardware.
Componentes de um Banco de Dados
Um Banco de Dados é composto pelas seguintes partes: renciador de Acesso ao
Disco: O SGBD utiliza o Sistema Operacional para acessar os dados armazenados em
disco, controlando o acesso concorrente às tabelas do Banco de Dados. O Gerenciador
controla todas as pesquisas queries) solicitadas pelos usuários no modo interativo, os
acessos do compilador DML, os acessos feitos pelo Processador do Banco de Dados
ao Dicionário de Dados e também aos próprios dados.
O Compilador DDL (Data Definition Language) processa as definições do esquema do
Banco de Dados, acessando quando necessário o Dicionário de Dados do Banco de
Dados.
36
O Dicionário de Dados contém o esquema do Banco de Dados, suas tabelas, índices,
forma de acesso e relacionamentos existentes.
O Processador do Banco de Dados manipula requisições à própria Base de Dados
em tempo de execução. É o responsável pelas atualizações e integridade da Base de
Dados.
O Processador de Pesquisas (queries) dos usuários, analisa as solicitações, e se
estas forem consistentes, aciona o Processador do Banco de Dados para acesso
efetivo aos dados.
As aplicações fazem seus acessos ao pré-compilador DML da linguagem hospedeira,
que os envia ao Compilador DML (Data Manipulation Language) onde são gerados os
códigos de acesso ao Banco de Dados.
Banco de Dados Relacional
O Modelo de Dados relacional representa os dados contidos em um Banco de Dados
através de relações. Estas relações contém informações sobre as entidades
representadas e seus relacionamentos. O Modelo Relacional, é claramente baseado no
conceito de matrizes, onde as chamadas linhas (das matrizes) seriam os registros e as
colunas (das matrizes) seriam os campos. Os nomes das tabelas e dos campos são de
fundamental importância para nossa compreensão entre o que estamos armazenando,
onde estamos armazenando e qual a relação existente entre os dados armazenados.
Cada linha de nossa relação será chamada de TUPLA e cada coluna de nossa relação
será chamada de ATRIBUTO. O conjunto de valores passíveis de serem assumidos
por um atributo, será intitulado de DOMÍNIO.
Toda a Informação de um banco de dados relacional é armazenada em Tabelas, que
na linguagem do modelo relaciona, também são chamadas de Entidades. Por exemplo,
posso ter uma Tabela "Clientes", onde seriam armazenadas informações sobre os
diversos clientes.
Essas diversas características de cada Cliente são os "Atributos" da entidade Cliente,
também chamados de campos da tabela Cliente.
Com isso temos uma Tabela que é constituída por um conjunto de Registros (uma linha
completa com informações sobre o cliente) e cada Registro formado por um conjunto
de atributos (Nome, Endereço, etc).
Um dos grandes desafios em se projetar um Banco de Dados com sucesso é a correta
Determinação das Entidades que existirão no Banco de Dados, bem como dos
Atributos de Cada Entidade.
37
Chave Primária - O Conceito de "Chave Primária" é fundamental para o correto
entendimento de como funciona um Banco de Dados baseado no modelo relacional.
Vamos entender o que significa um campo ser a Chave Primária de uma Tabela e
como tornar um Campo a Chave Primária de uma Tabela.
"Ao Definirmos um Campo como sendo uma Chave Primária, estamos informando ao
SGBD que não podem existir dois registros com o mesmo valor no campo que é a
Chave Primária, ou seja, os valores no campo Chave Primária precisam ser únicos".
Por exemplo, se defino um campo "Número da Identidade", da tabela Clientes, como
sendo um campo do tipo Chave Primária, estou dizendo que não podem ser
cadastrados dois clientes com o mesmo valor no campo "Número da Identidade". Na
prática estou garantindo que não possam ser cadastrados dois clientes com o mesmo
Número de Identidade". Exemplos de Chaves primárias
. Campo CPF.
. Campo CNPJ.
. Matrícula do aluno.
. Código da Peça.
. Matrícula do funcionário.
. Número do pedido.
Após ter definido um campo como sendo a Chave Primária da tabela, o próprio banco
de dados (quer seja Access, SQL Server, ORACLE ou qualquer outro), garante que
não sejam inseridos dados duplicados no campo que é a chave primária.
Um último detalhe importante para lembrarmos é que a Chave Primária pode ser
formada pela combinação de Mais de Um Campo. Podem existir casos em que um
único campo não é capaz de atuar como chave primária, pelo fato deste apresentar
valores repetidos. Nestes casos podemos definir uma combinação de 2 ou mais
campos para ser a nossa chave primária.Não podemos definir 2 chaves primárias em
uma tabela.
Chave Composta - aquela chave que contém mais de um atributo (Por exemplo um
cadastro ordenado alfabeticamente por Estado, Cidade e Nome do Cliente, necessitaria
de uma chave composta que contivesse estes três atributos).
Chave Estrangeira - aquela chave que permitir a ligação lógica entre uma tabela (onde
ela se encontra) com outra na qual ele é chave primária.
Relacionamentos entre Tabelas
relacionamentos entre as tabelas. Por exemplo: Um Pedido é feito por um Cliente e
neste Pedido podem existir diversos itens, itens que são gravados na tabela Detalhes
do Pedido. Além disso cada Pedido possui um número único (Código do pedido), mas
um mesmo Cliente pode fazer diversos pedidos e assim por diante.
Em um banco de dados, precisamos de alguma maneira para representar estes
relacionamentos da vida Real, em termos das tabelas e de seus atributos. Isto é
38
possível com a utilização de "Relacionamentos entre tabelas", os quais podem ser de
três tipos:
. Um para Um (1:1)
. Um para Vários (1:N)
. Vários para Vários (N:N)
Relacionamento do Tipo Um para Um:
Esta relação existe quando os campos que se relacionam são ambos do tipo Chave
Primária, em suas respectivas tabelas. Cada um dos campos não apresenta valores
repetidos. Na prática existem poucas situações onde utilizaremos um relacionamento
deste tipo. Um exemplo poderia ser o seguinte: Imagine uma escola com um Cadastro
de Alunos na tabela Alunos, destes apenas uma pequena parte participa da Banda da
Escola. Por questões de projeto do Banco de Dados, podemos criar uma Segunda
Tabela "Alunos da Banda", a qual se relaciona com a tabela Alunos através de um
relacionamento do tipo Um para Um. Cada aluno somente é cadastrada uma vez na
Tabela Alunos e uma única vez na tabela Alunos da Banda. Poderíamos utilizar o
Campo Matrícula do Aluno como o Campo que relaciona as duas Tabelas.
Importante: O campo que relaciona duas tabelas deve fazer parte, ter sido definido, na
estrutura das duas tabelas.
Na Figura a seguir vemos o exemplo de um Relacionamento do tipo Um para Um entre
as tabelas Alunos e Alunos da Banda.
Figura 1: Relacionamento Um para Um entre as Tabelas Alunos e Alunos da Banda
Com a criação deste relacionamento estamos evitando a repetição desnecessária de
informações em diferentes tabelas.
Relacionamento do Tipo Um para Vários:
Este é, com certeza, o tipo de relacionamento mais comum entre duas tabelas. Uma
das tabelas (o lado um do relacionamento) possui um campo que é a Chave Primária
e a outra tabela (o lado vários) se relaciona através de um campo cujos valores
relacionados podem se repetir várias vezes.
Considere o exemplo entre a tabela Clientes e Pedidos. Cada Cliente somente é
cadastrado uma única vez na tabela de Clientes (por isso o campo Código do Cliente,
na tabela Clientes, é uma chave primária, indicando que não podem ser cadastrados
dois clientes com o mesmo código), portanto a tabela Clientes será o lado um do
39
relacionamento. Ao mesmo tempo cada cliente pode fazer diversos pedidos, por isso
que o mesmo Código de Cliente poderá aparecer várias vezes na tabela Pedidos:
tantas vezes quantos forem os pedidos que o Cliente tiver feito. Por isso que
temos um relacionamento do tipo Um para Vários entre a tabela Clientes e Pedidos,
através do campo Código do Cliente, indicando que um mesmo Cliente pode realizar
diversos (vários) pedidos.
Na próxima figura vemos um exemplo de um Relacionamento Um para Vários entre as
Tabelas Clientes e Pedidos do banco de dados Pedidos.mdb, através do campo código
do cliente:
Figura 2: Relacionamento Um para Vários entre as Tabelas Clientes e Pedidos
Relacionamento do tipo Vários para Vários:
Este tipo de relacionamento "aconteceria" em uma situação onde em ambos os lados
do relacionamento os valores poderiam se repetir. Vamos considerar o caso entre
Produtos e Pedidos. Posso ter Vários Pedidos nos quais aparece um determinado
produto, além disso vários Produtos podem aparecer no mesmo Pedido. Esta é uma
situação em que temos um Relacionamento do Tipo Vários para Vários.
Na prática não é possível implementar um relacionamento deste tipo, devido a uma
série de problemas que seriam introduzidos no modelo do banco de dados. Por
exemplo, na tabela Pedidos teríamos que repetir o Número do Pedido, Nome do
Cliente, Nome do Funcionário, Data do Pedido, etc. para cada item do Pedido.
Para evitar este tipo de problema é bastante comum "quebrarmos" um
relacionamento do tipo Vários para Vários em dois relacionamentos do tipo Um para
Vários.
Isso é feito através da criação de uma nova tabela, a qual fica com o lado, Vários dos
relacionamentos. No nosso exemplo vamos criar a tabela Detalhes do Pedido, onde
ficam armazenadas as informações sobre os diversos itens de cada pedido, aí ao invés
de termos um relacionamento do tipo Vários para Vários, teremos dois relacionamentos
do tipo um para vários, conforme descrito pela próxima tabela:
40
Na figura abaixo temos a representação dos dois relacionamentos Um para Vários,
resultantes da quebra do relacionamento vários-para-vários:
Tabela Detalhes do Pedido ficou com o lado, Vários dos Relacionamentos.
Integridade Referencial
A Integridade Referencial é utilizada para garantir a Integridade dos dados entre as
tabelas relacionadas. Por exemplo, considere um relacionamento do tipo Um-paraVários entre a tabela Clientes e a tabela Pedidos (um cliente pode fazer vários
pedidos). Com a Integridade Referencial, o banco de dados não permite que seja
cadastrado um pedido para um cliente que ainda não foi cadastrado. Em outras
palavras, ao cadastrar um pedido, o banco de dados verifica se o código do cliente que
foi digitado já existe na tabela Clientes. Se não existir, o cadastro do pedido não será
aceito. Com o uso da Integridade Referencial é possível ter as seguintes garantias
(ainda usando o exemplo entre as tabelas Clientes e Pedidos):
. Quando o Código de um cliente for alterado na Tabela Clientes, podemos configurar
para o banco de dados atualizar, automaticamente, todos os Códigos do Cliente na
Tabela Pedidos, de tal maneira que não fiquem Registros Órfãos, isto é , registros de
Pedidos com um Código de Cliente para o qual não existe mais um correspondente na
Tabela Clientes. Essa ação é conhecida como "Propagar atualização dos campos
relacionados".
. Quando um Cliente for excluído da Tabela Clientes, podemos configurar para que o
banco de dados exclua, automaticamente, na tabela Pedidos, todos os Pedidos para o
Cliente que está sendo Excluído. Essa opção é conhecida como "Propagar exclusão
dos registros relacionados".
Modelagem de Dados
Um banco de dados representa uma coleção de dados que possui algum significado e
objetiva atender a um conjunto de usuários. Por exemplo , um catálogo telefônico pode
ser considerado um BD, sendo assim um BD não necessariamente está informatizado.
Quando resolvemos informatizar um BD, utilizamos um programa especial para essa
tarefa, o denominado SGBD ( Sistema de Gerenciamento de Banco de Dados ).
41
Podemos citar como exemplos o SQL Server, Access, Oracle, MySql, InterBase,
FireBord, entre outros. Estes programas em geral armazenam os dados em uma
estrutura chamada Tabela. Nesse modelo, as tabelas são relacionadas, permitindo
assim que possamos recuperar informações envolvendo várias delas. Observe o
exemplo abaixo :
Tabela Clientes
Código
1
2
3
Nome
Marcio
Marcos
Luciane
DataNascimento
1/6/1975
5/8/1980
10/5/1970
Tabela Telefones
Código
1
1
3
Fone
22548954
88512547
26539955
Tipo
Residencial
Celular
Residencial
Neste caso, a Tabela Clientes está relacionada com a tabela Telefones. Note que o
cliente Marcio tem 2 telefones : um Residencial e outro Celular.
Entretanto, para que possamos implementar, de forma correta, um BD utilizando um
SGBD , temos que passar por uma fase intermediária e não menos importante,
chamada modelagem de dados.
Está etapa é dividida em 3 partes :
- Entendendo o problema;
- Construção do MER – Modelagem de Dados e Relacionamento
- Implementação ( SGBD )
Entender determinado problema nem sempre é uma tarefa fácil, principalmente se você
não está familiarizado com a área de atuação de seu cliente. O profissional de
informática precisa dominar a tecnologia, e além disso precisa saber ouvir o cliente e
ao mesmo tempo entender o que realmente ele precisa.
Antes da implementação em um SGBD, precisamos de uma descrição formal da
estrutura do banco de dados ( MER ).
42
Entidade – Pode ser entendida como uma “coisa” ou algo da realidade onde se deseja
manter informações no banco de dados. Por exemplo, em um colégio, algumas
entidades podem ser os alunos, horários, professores, matérias e avaliações. Note que
uma entidade pode ser tanto objetos concretos ( Alunos ) como abstratos ( Horários ).
A entidade é representada por um retângulo.
Relacionamento – É um conjunto de associações entre entidades. O relacionamento é
representado por um losango. Esse losango é ligado por linhas aos retângulos que
representam as entidades participantes do relacionamento.
Cardinalidade do relacionamento
Empregado
Possui
Dependente
Estamos diante de um relacionamento (possui) entre as entidades Empregado e
Dependente. Considere as seguintes perguntas :
- Um empregado pode não ter dependentes ? Pode
- Um dependente pode ter mais de um empregado associado ? Pode Pai e Mãe
- Determinado empregado pode ter mais de um dependente ? Pode 2 filhos
- Pode existir dependentes sem algum empregado associado ? Não
Na realidade, as respostas dessas perguntas dependem do problema sendo modelado.
Entretanto , para que possamos expressar essas idéias no modelo, é necessário definir
uma propriedade importante a cardinalidade.
A Cardinalidade é um número que expressa o comportamento ( número de ocorrências
) de determinada entidade associada a uma ocorrência da entidade em questão
através do relacionamento.
Existem dois tipos de cardinalidade : mínima e máxima. A cardinalidade máxima
expressa o número máximo de ocorrências de uma determinada entidade, associada a
uma ocorrência da entidade em questão, através do relacionamento. A cardinalidade
mínima, expressa o número mínimo de ocorrências de determinada entidade associada
a uma ocorrência da entidade em questão através do relacionamento.
Usaremos a seguinte convenção para expressar a cardinalidade:
43
Número ( mínimo, máximo )
Empregado
(1,1)
Possui
(0,N)
Dependente
Para fazermos a leitura do modelo, partimos de determinada entidade e a cardinalidade
correspondente é representada do lado oposto. Em nosso exemplo , a cardinalidade
(0,N) faz referencia a entidade Empregado, já a cardinalidade (1,1) faz referencia a
entidade Dependente.
Na Prática , para as cardinalidades máximas , costumamos usar dois tipos : 1 e N, já
para a mínima costumamos usar : 0 e 1
Atributo – É uma característica relevante associada a cada ocorrência de entidade ou
relacionamento. Observe no modelo abaixo a notação utilizada para atributos :
Telefone
Nome
Código
Cardinalidade do atributo :
Observe que no modelo acima não informa se determinado aluno pode ter vários
telefones, ou mesmo se algum aluno pode não ter telefones. Para deixar o modelo
mais preciso, costumamos expressar cardinalidade para atributos. Observe a
cardinalidade do atributo telefone no modelo abaixo :
44
Telefone (0,N)
Nome
Código
Dessa forma, podemos concluir que determinado aluno pode não ter telefone ou pode
ter vários. A cardinalidade dos atributos código e nome é (1,1). Por convenção , ela foi
omitida do diagrama.
No caso de cardinalidade mínima = 1 indica que o atributo é obrigatório e 0 que ele é
opcional.
Para deixarmos o modelo de entidade e relacionamento mais preciso, é necessário
distinguir uma ocorrência da outra. Sendo assim, cada entidade deve possuir um
identificador. Há várias formas de identificarmos entidades:
Aluno
Nome
Código
Neste caso, a entidade aluno possui um único identificador (código). Em outras
palavras, cada aluno deve possuir um código diferente.
Existem situações onde é necessário mais de um atributo para identificar determinada
entidade:
45
Fabricante
Prateleira
Número do Corredor
Número da prateleira
Imagine uma biblioteca onde os livros ficam armazenados em prateleiras. Estas
prateleiras encontram-se organizadas em corredores. Desta forma, para identificar uma
prateleira é necessário conhecer seu número, além do número do corredor
correspondente.
SQL - Structured Query Language
Introdução
Quando os Bancos de Dados Relacionais estavam sendo desenvolvidos, foram criadas
linguagens destinadas à sua manipulação. O Departamento de Pesquisas da IBM,
desenvolveu a SQL como forma de interface para o sistema de BD relacional
denominado SYSTEM R, início dos anos 70. Em 1986 o American National Standard
Institute ( ANSI ), publicou um padrão SQL.
A SQL estabeleceu-se como linguagem padrão de Banco de Dados Relacional.
SQL apresenta uma série de comandos que permitem a definição dos dados, chamada
de DDL (Data Definition Language), composta entre outros pelos comandos Create,
que é destinado à criação do Banco de Dados, das Tabelas que o compõe, além das
relações existentes entre as tabelas. Como exemplo de comandos da classe DDL
temos os comandos Create, Alter e Drop.
Os comandos da série DML (Data Manipulation Language), destinados a consultas,
inserções, exclusões e alterações em um ou mais registros de uma ou mais tabelas de
maneira simultânea. Como exemplo de comandos da classe DML temos os comandos
Select, Insert, Update e Delete.
Uma subclasse de comandos DML, a DCL (Data Control Language), dispõe de
comandos de controle como Grant e Revoke.
A Linguagem SQL tem como grandes virtudes sua capacidade de gerenciar índices,
sem a necessidade de controle individualizado de índice corrente, algo muito comum
nas linguagens de manipulação de dados do tipo registro a registro. Outra
característica muito importante disponível em SQL é sua capacidade de construção de
visões, que são formas de visualizarmos os dados na forma de listagens independente
das tabelas e organização lógica dos dados.
Outra característica interessante na linguagem SQL é a capacidade que dispomos de
cancelar uma série de atualizações ou de as gravarmos, depois de iniciarmos uma
46
seqüência de atualizações. Os comandos Commit e Rollback são responsáveis por
estas facilidades.
Devemos notar que a linguagem SQL consegue implementar estas soluções, somente
pelo fato de estar baseada em Banco de Dados, que garantem por si mesmo a
integridade das relações existentes entre as tabelas e seus índices.
PARTE I - Comandos de Modificações do Esquema e Criação de Banco de Dados
Comando Create
Este comando permite a criação de tabelas no banco de dados ou mesmo de sua
criação.
Sintaxe:
CREATE DATABASE < nome_db >;
onde:
nome_db - indica o nome do Banco de Dados a ser criado.
Sintaxe:
CREATE TABLE < nome_tabela >
( nome_atributo1 < tipo > [ NOT NULL ],
nome_atributo2 < tipo > [ NOT NULL ],
......
nome_atributoN < tipo > [ NOT NULL ] ) ;
onde:
nome_table indica o nome da tabela a ser criada.
nome_atributo indica o nome do campo a ser criado na tabela.
tipo indica a definição do tipo de atributo ( integer(n), char(n),
real(n,m), date... ).
n- número de dígitos ou de caracteres
m- número de casas decimais
Agora vamos criar uma tabela. Use o editor para salvar em um arquivo ou digite na
linha de comando do ISQL.
CREATE DATABASE TRABALHO;
O comando acima criou um Banco de Dados, porém este na verdade não passa de
uma abertura no diretório, pois não conta com nenhuma tabela.
Agora criaremos as tabelas que estarão contidas no Banco de Dados TRABALHO.
A primeira Tabela será a de Departamentos (DEPT). Esta tabela conterá além dos
campos também sua chave primária, suas chaves estrangeiras e também seus índices.
A segunda tabela será a de Empregados (EMP), que também será criada.
Não devemos esquecer de primeiramente abrirmos o Banco de Dados. Diferentemente
do que ocorre em alguns aplicativos, em SQL o fato de criarmos um Banco de Dados,
47
não significa que o banco recém criado já está preparado para utilização. A instrução a
seguir, providencia a abertura do Banco de Dados criado.
OPEN DATABASE TRABALHO;
Agora estamos prontos para criarmos as tabelas necessárias. Lembramos aos
Estudantes, que o Arquivo TABS.SQL, contém todas as instruções necessárias para
criação do Banco de Dados Trabalho e de suas tabelas. Já o Arquivo DADOS.SQL irá
popular estas tabelas. Para efeitos didáticos, criamos as tabelas de forma que sua
população, em outras palavras os dados, sejam facilmente referenciáveis pelos
estudantes. Assim sendo, na tabela de departamentos, contamos com 5
departamentos, cada um deles tendo seu gerente. Todos os “gerentes” tem nomes de
cantoras brasileiras (Gal Costa, Marina Lima, etc), todos os “operários” tem nomes de
jogadores de futebol, todas as vendedoras tem nomes de jogadoras de vôlei, todas as
balconistas tem nome de jogadoras de basquete e o presidente da empresa exemplo,
tem o mesmo nome do presidente do Brasil. Desta forma os testes devem resultar em
grupos bastante definidos. Assim se você estiver listando Gerentes e aparecer um
homônimo da Ana Paula (jogadora de vôlei), verifique sua query atentamente, pois
muito provavelmente a mesma estará errada.
A seguir código necessário à criação da tabela Departamento e seu índice:
create table Dept
(DepNume
integer(4) not null,
DepNome
char(20) not null,
DepLoca
char(20) not null,
DepOrca
integer(12,2),
primary key (DepNume)
);
create unique index DepNum on Dept (DepNume asc);
Note-se que a chave primária já está definida juntamente com o registro da tabela. A
criação do índice, que por razões óbvias deve ser criado após a tabela, naturalmente é
um comando totalmente independente do primeiro create, que serviu para criar a tabela
e suas característica básicas.
Vamos analisar o código necessário para a criação da tabela de empregados,
apresentado a seguir:
create table Emp
(EmpNume
integer(5) not null,
EmpNome
char(30) not null,
EmpGere
integer(5) ,
EmpServ
char(20) ,
DepNume
integer(4) not null,
EmpAdmi
date
not null,
EmpSala
integer(10,2),
EmpComi
integer(10,2),
primary key (EmpNume),
foreign key has (DepNume)
48
references Dept
on delete restrict
on update cascade
);
create unique index EmpNum on Emp (EmpNume asc);
create index EmpDep on Emp (DepNume asc);
A Tabela de Empregados não poderia ter sido criada antes da Tabela de
Departamento, pois contém uma referência direta àquela tabela. Quando declaramos
que DepNume é chave estrangeira, promovemos de fato a ligação do cadastro de
empregados como o cadastro de departamentos. Ao restringirmos as exclusões,
permitimos a existência de funcionários não alocados a nenhum departamento. Apesar
desta prática ser contrária a tese de que devemos possuir apenas tuplas perfeitamente
relacionáveis em nossas tabelas, podemos deixar esta pequena abertura, pois um
usuário que excluisse inadvertidamente determinado departamento, acabaria por
excluir também uma grande quantidade de funcionários, que estivessem ligados a este
departamento.
Já a atualização em cascata dos códigos de departamento é uma boa providência, na
medida em que teremos, uma vez alterado algum código de departamento, a
atualização imediata de todos os funcionários pertencentes ao departamento cujo
código foi modificado.
Observações:
1 - Observar que os índices são parte intrínseca das tabelas.
2 - A integridade relacional é garantida pelo Banco de Dados e não pelo aplicativo.
3 - Exclusões ou Alterações em Chaves Primárias, podem acarretar exclusões,
anulações ou até mesmo perda de integridade nas tabelas onde esta chave primária
existir como chave estrangeira. Portanto é imprescindível muito cuidado quando da
elaboração do Banco de Dados. Uma tentação muito comum ao estudante é
começar criando as tabelas do Banco de Dados sem prévia Normalização. Este
talvez seja o melhor caminho para perder-se tempo em vão, pois quando você
terminar de projetar suas telas de entrada de dados, notará "que nada funciona!".
Esta será a senha para usar o velho comando DEL do DOS e depois começar tudo
de novo...
Comando Drop
Este comando elimina a definição da tabela, seus dados e referências.
Sintaxe:
DROP TABLE < nome_tabela > ;
Ex: DROP TABLE EMP;
49
Comando Alter
Este comando permite inserir/eliminar atributos nas tabelas já existentes.
Comando:
ALTER TABLE < nome_tabela > ADD / DROP (
nome_atributo1
< tipo >
[ NOT NULL ],
nome_atributoN
< tipo >
[ NOT NULL ] ) ;
Não existe nenhum comando SQL que permita eliminar algum atributo de uma relação
já definida. Assim caso você desejar eliminar uma chave primária devidamente
referenciada em outra tabela como chave estrangeira, ao invés de obter a eliminação
do campo, obterá apenas um erro.
Além do comando DROP que poderá eliminar uma tabela e suas relações, também
podemos criar uma relação que tenha os atributos que se deseja, copiar-se a relação
antiga sobre a nova e apagando-se então a relação que originalmente desejávamos
eliminar.
Ex: ALTER TABLE DEPT ( ADD DEPSALA DECIMAL (10,2) );
Exercício: Criar o Banco de Dados Mundo. Observar que se um continente for
excluído, todos os países contidos em tal continente também o serão. Esta situação é
conhecida como exclusão em Cascata. Observar também que a exclusão de um País
eliminará todas as Cidades contidas no mesmo.
Prática
O Exemplo Trabalho já possui pequeno programa destinado a construção das tabelas
contidas no Banco de Dados TRABALHO. Execute "trabalho.sql" de forma a obter as
tabelas acima sem necessidade de digitar as instruções SQL de maneira interativa.
Para tanto, você deverá copiar para seu diretório de trabalho o arquivo "trabalho.sql" do
diretório \IDEO\SQL.
Execute: "@trabalho;" que deverá:
- Criar o banco de dados Trabalho.
- Abrir o banco de dados Trabalho.
- Criar as Tabelas, Índices e Relações contidas neste Banco de Dados.
Posteriormente execute o comando "show tables", que deverá exibir as tabelas "dept" e
"emp".
E ao executar "show fields dept" serão exibidos os campos da tabela "dept".
Copie e execute enchetra.sql do diretório \IDEO\SQL de forma a obter um conjunto de
dados preparados para os testes a seguir apresentados.
Na próxima etapa de nosso curso, estaremos realizando pesquisas utilizando a
instrução Select. Julgamos conveniente que os estudantes populem seu exercício e
realizem exercícios análogos aos apresentados na Base de Dados Trabalho no Banco
de Dados Mundo.
50
Parte II - Comandos de Consulta ao Esquema
Devemos ressaltar que a linguagem SQL é utilizada tanto pelos profissionais
responsáveis pelos dados, onde é ressaltada a figura do Administrador do Banco de
Dados e dos Analistas de Dados, como também pelos desenvolvedores de Aplicações.
Enquanto àqueles estão preocupados com o desempenho, integridade do Banco de
Dados e utilizam toda gama de recusos disponíveis no SQL, estes estão preocupados
apenas em "transformar dados em informações", portanto para os desenvolvedores
costuma-se dizer que conhecer o "select" já basta. Em nosso curso enfatizaremos a
importância de TODOS os comandos do SQL, mas sabemos de antemão que os
professores responsáveis pelas linguagens IDEO, VB e Delphi, ressaltarão a
preponderância da instrução "select", que será apresentada a seguir e não no final do
curso de SQL como geralmente acontece, pelo fato de que diversas disciplinas
necessitam especificamente deste comando, que passaremos a apresentar:
1) Seleção de todas os campos (ou colunas) da tabela de Departamentos.
Resp:
SELECT * FROM DEPT;
O exemplo utiliza o coringa "*" para selecionar as colunas na ordem em que foram
criadas. A instrução Select, como pudemos observar seleciona um grupo de registros
de uma (ou mais) tabela(s). No caso a instrução From nos indica a necessidade de
pesquisarmos tais dados apenas na tabela Dept.
Where como base das Restrição de tuplas.
A cláusula "where" corresponde ao operador restrição da álgebra relacional. Contém a
condição que as tuplas devem obedecer a fim de serem listadas. Ela pode comparar
valores em colunas, literais, expressões aritméticas
ou funções.
A seguir apresentamos operadores lógicos e complementares a serem utilizados nas
expressões apresentadas em where.
Operadores lógicos
operador
=
>
>=
<
<=
significado
igual a
maior que
maior que ou igual a
menor que
menor que ou igual a
Exemplos:
SELECT EMPNOME, EMPSERV
FROM EMP
WHERE DEPNUME > 10;
SELECT EMPNOME, EMPSERV
51
FROM EMP
WHERE EMPSERV = 'GERENTE';
O conjunto de caracteres ou datas devem estar entre apóstrofes (‘)
"where".
na cláusula
2) Selecione todos os departamentos cujo orçamento mensal seja maior que
100000. Apresente o Nome de tal departamento e seu orçamento anual, que
será obtido multiplicando-se o orçamento mensal por 12.
Resp: Neste problema precisamos de uma expressão que é a combinação de um ou
mais valores, operadores ou funções que resultarão em um valor. Esta expressão
poderá conter nomes de colunas, valores numéricos, constantes e operadores
aritméticos.
SELECT DEPNOME, DEPORCA * 12
FROM DEPT
WHERE DEPORCA > 100000;
3) Apresente a instrução anterior porém ao invés dos "feios" DepNome e
DepOrca, os Títulos Departamento e Orçamento.
Resp: Neste exemplo deveremos denominar colunas por apelidos. Os nomes das
colunas mostradas por uma consulta, são geralmente os nomes existentes no
Dicionário de Dado, porém geralmente estão armazenados na forma do mais puro
"informatiquês", onde "todo mundo" sabe que CliCodi significa Código do Cliente. É
possível (e provável) que o usuário desconheça estes símbolos, portanto devemos os
apresentar dando apelidos às colunas "contaminadas" pelo informatiquês, que apesar
de fundamental para os analistas, somente são vistos como enigmas para os usuários.
SELECT DEPNOME "DEPARTAMENTO", DEPORCA * 12 "ORCAMENTO ANUAL"
FROM DEPT
WHERE DEPORCA > 100000;
4) Apresente todos os salários existentes na empresa, porém omita eventuais
duplicidades.
Resp: A cláusula Distinct elimina duplicidades, significando que somente relações
distintas serão apresentadas como resultado de uma pesquisa.
SELECT DISTINCT EMPSERV
FROM EMP;
5) Apresente todos os dados dos empregados, considerando sua existência
física diferente de sua existência lógica (ou seja devidamente inicializado).
Resp: Desejamos um tratamento diferenciado para valores nulos. Qualquer coluna de
uma tupla que não contenha informações é denominada de nula, portanto informação
não existente. Isto não é o mesmo que "zero", pois zero é um número como outro
52
qualquer, enquanto que um valor nulo utiliza um "byte" de armazenagem interna e são
tratados de forma diferenciada pelo SQL.
SELECT EMPNOME, EMPSALA + EMPCOMI
FROM EMP;
SELECT EMPNOME, NVL(EMPSALA,0) + NVL(EMPCOMI,0)
FROM EMP;
Obs: a função "NVL" é utilizada para converter valores nulos em zeros.
6) Apresente os nomes e funções da cada funcionário contidos na tabela
empresa, porém classificados alfabeticamente (A..Z) e depois alfabeticamente
invertido (Z..A).
Resp: A cláusula Order By modificará a ordem de apresentação do resultado da
pesquisa (ascendente ou descendente).
SELECT EMPNOME, EMPSERV
FROM EMP
ORDER BY EMPNOME;
SELECT EMPNOME, EMPSERV
FROM EMP
ORDER BY EMPPNOME DESC;
Nota: Também é possível fazer com que o resultado da pesquisa venha classificado
por várias colunas. Sem a cláusula "order by" as linhas serão exibidas na seqüência
que o SGBD determinar.
7) Selecione os Nomes dos Departamentos que estejam na fábrica.
Resp:
SELECT DEPNOME
FROM DEPT
WHERE DEPLOCA = "SAO PAULO";
O exemplo exigiu uma restrição (São Paulo) que nos obrigou a utilizar da instrução
Where. Alguns analistas costumam afirmar em tom jocoso que SQL não passa de
"Selecione algo De algum lugar Onde se verificam tais relações"
Acreditamos que esta brincadeira pode ser útil ao estudante, na medida em que facilita
sua compreensão dos objetivos elementares do SQL.
53
Demais Operadores
Operador
Significado
between ... and ...
entre dois valores ( inclusive )
in ( .... )
lista de valores
like
com um padrão de caracteres
is null
é um valor nulo
Exemplos:
SELECT EMPNOME, EMPSALA
FROM EMP
WHERE EMPSALA BETWEEN 500 AND 1000;
SELECT EMPNOME, DEPNUME
FROM EMP
WHERE DEPNUME IN (10,30);
SELECT EMPNOME, EMPSERV
FROM EMP
WHERE EMPNOME LIKE 'F%';
SELECT EMPNOME, EMPSERV
FROM EMP
WHERE EMPCOMI IS NULL;
O símbolo "%" pode ser usado para construir a pesquisa ("%" = qualquer seqüência de
nenhum até vários caracteres).
Operadores Negativos
operador
<>
not nome_coluna =
not nome_coluna >
not between
not in
not like
is not null
descrição
diferente
diferente da coluna
não maior que
não entre dois valores informados
não existente numa dada lista de valores
diferente do padrão de caracteres informado
não é um valor nulo
8) Selecione os Empregados cujos salários sejam menores que 1000 ou maiores
que 3500.
Resp: Necessitaremos aqui a utilização de expressão negativas. A seguir
apresentamos operadores negativos.
SELECT EMPNOME, EMPSALA
FROM EMP
WHERE EMPSALA NOT BETWEEN 1000 AND 3500;
54
9) Apresente todos os funcionários com salários entre 200 e 700 e que sejam
Vendedores.
Resp: Necessitaremos de consultas com condições múltiplas.
Operadores "AND" (E) e "OR" (OU).
SELECT EMPNOME, EMPSALA, EMPSERV
FROM EMP
WHERE EMPSALA BETWEEN 700 AND 2000
AND EMPSERV = 'VENDEDOR';
10) Apresente todos os funcionários com salários entre 200 e 700 ou que sejam
Vendedores.
Resp:
SELECT EMPNOME, EMPSALA, EMPSERV
FROM EMP
WHERE EMPSALA BETWEEN 700 AND 2000
OR EMPSERV = 'VENDEDOR';
11) Apresente todos os funcionários com salários entre 200 e 700 e que sejam
Vendedores ou Balconistas.
Resp:
SELECT EMPNOME, EMPSALA, EMPSERV
FROM EMP
WHERE EMPSALA BETWEEN 700 AND 2000
AND ( EMPSERV = 'BALCONISTA' OR EMPSERV = 'VENDEDOR' );
Funções de Caracteres
Lower Upper Concat(x,y)Substring(x,y,str)"y".
To_Char(num)To_Date(char,fmt)^Q -
força caracteres maiúsculos aparecerem em minúsculos.
força caracteres minúsculos aparecerem em maiúsculos.
concatena a string "x" com a string "y".
extrai um substring da string "str", começando em "x", e termina em
converte um valor numérico para uma string de caracteres.
converte uma string caracter em uma data.
converte data para o formato apresentado.
12) Apresente o nome de todos os empregados em letras minúsculas.
Resp:
SELECT LOWER( EMPNOME )
FROM EMP;
55
13) Apresente o nome de todos os empregados (somente as 10 primeiras letras).
Resp:
SELECT SUBSTRING (1,10,EMPNOME)
FROM EMP;
14) Apresente o nome de todos os empregados admitidos em 01/01/80.
Resp:
SELECT *
FROM EMP
WHERE EMPADMI = ^Q"DD-AAA-YYYY"("01-JAN-1980");
ou
SELECT *
FROM EMP
WHERE EMPADMI = ^Q("01-JAN-1980");
Funções Agregadas (ou de Agrupamento)
função
avg(n)
count(expr)
max(expr)
min(expr)
sum(n)
retorno
média do valor n, ignorando nulos
vezes que o número da expr avalia para algo não nulo
maior valor da expr
menor valor da expr
soma dos valores de n, ignorando nulos
15) Apresente a Média, o Maior, o Menor e também a Somatória dos Salários
pagos aos empregados.
Resp:
SELECT AVG(EMPSALA) FROM EMP;
SELECT MIN(EMPSALA) FROM EMP;
SELECT MAX(EMPSALA) FROM EMP;
SELECT SUM(EMPSALA) FROM EMP;
Agrupamentos
As funções de grupo operam sobre grupos de tuplas(linhas). Retornam resultados
baseados em grupos de tuplas em vez de resultados de funções por tupla individual. A
cláusula "group by" do comando "select" é utilizada para dividir tuplas em grupos
menores.
A cláusula "GROUP BY" pode ser usada para dividir as tuplas de uma tabela em
grupos menores. As funções de grupo devolvem uma informação sumarizada para
cada grupo.
56
16) Apresente a média de salário pagos por departamento.
Resp:
SELECT DUPNUME, AVG(EMPSALA)
FROM EMP
GROUP BY DEPNUME;
Obs.: Qualquer coluna ou expressão na lista de seleção, que não for uma função
agregada, deverá constar da cláusula "group by". Portanto é errado tentar impor uma
"restrição" do tipo agregada na cláusula Where.
Having
A cláusula "HAVING" pode ser utilizada para especificar quais grupos deverão ser
exibidos, portanto restringindo-os.
17) Retome o problema anterior, porém apresente resposta apenas para
departamentos com mais de 10 empregados.
Resp:
SELECT DEPNUME, AVG(EMPSALA)
FROM EMP
GROUP BY DEPNUME
HAVING COUNT(*) > 3;
Obs.: A cláusula "group by" deve ser colocada antes da "having", pois os grupos são
formados e as funções de grupos são calculadas antes de se resolver à cláusula
"having".
A cláusula "where" não pode ser utilizada para restringir grupos que deverão ser
exibidos.
Exemplificando ERRO típico - Restringindo Média Maior que 1000:
SELECT DEPNUME, AVG(EMPSALA)
FROM EMP
WHERE AVG(SALARIO) > 1000
GROUP BY DEPNUME;
( Esta seleção está ERRADA! )
SELECT DEPNUME, AVG(EMPSALA)
FROM EMP
GROUP BY DEPNUME
HAVING AVG(EMPSALA) > 1000;
( Seleção Adequada )
57
Seqüência no comando "Select":
SELECT
FROM
WHERE
GROUP BY
HAVING
ORDER BY
coluna(s)
tabela(s)
condição(ões) da(s) tupla(s)
condição(ões) do(s) grupo(s) de tupla(s)
condição(ões) do(s) grupo(s) de tupla(s)
coluna(s);
A "sql" fará a seguinte avaliação:
a) WHERE, para estabelecer tuplas individuais candidatas (não pode conter funções de
grupo)
b) GROUP BY, para fixar grupos.
c) HAVING, para selecionar grupos para exibição.
Equi-Junção ( Junção por igualdade )
O relacionamento existente entre tabelas é chamado de equi-junção, pois os valores de
colunas das duas tabelas são iguais. A Equi-junção é possível apenas quando tivermos
definido de forma adequada a chave estrangeira de uma tabela e sua referência à
chave primária da tabela precedente. Apesar de admitir-se em alguns casos, a equijunção de tabelas, sem a correspondência Chave Primária-Chave Estrangeira,
recomendamos fortemente ao estudante não utilizar este tipo de construção, pois
certamente em nenhum momento nos exemplos propostos em nossa disciplina ou nas
disciplinas de Análise e Projeto de Sistemas, serão necessárias tais junções.
18) Listar Nomes de Empregados, Cargos e Nome do Departamento onde o
empregado trabalha.
Resp: Observemos que dois dos três dados solicitados estão na Tabela Emp, enquanto
o outro dado está na Tabela Dept. Deveremos então acessar os dados restringindo
convenientemente as relações existentes entre as tabelas. De fato sabemos que
DEPNUME é chave primária da tabela de Departamentos e também é chave
estrangeira da Tabela de Empregados. Portanto, este campo será o responsável pela
equi-junção.
SELECT A.EMPNOME, A.EMPSERV, B.DEPNOME
FROM EMP A, DEPT B
WHERE A.DEPNUME = B.DEPNUME;
Obs.: Note que as tabelas quando contém colunas com o mesmo nome, usa-se um
apelido "alias" para substituir o nome da tabela associado à coluna. Imagine que
alguém tivesse definido NOME para ser o Nome do Empregado na Tabela de
Empregados e também NOME para ser o Nome do Departamento na Tabela de
Departamentos. Tudo funcionaria de forma adequada, pois o aliás se encarregaria de
evitar que uma ambigüidade fosse verificada. Embora SQL resolva de forma muito
elegante o problema da nomenclatura idêntica para campos de tabelas, recomendamos
que o estudante fortemente evite tal forma de nomear os campos. O SQL nunca
confundirá um A.NOME com um B.NOME, porém podemos afirmar o mesmo de nós
mesmos?
58
19) Liste os Códigos do Cada Funcionário, seus Nomes, seus Cargos e o nome
do Gerente ao qual este se relaciona.
Resp: Precisamos criar um auto-relacionamento, ou seja, juntar uma tabela a ela
própria. É possível juntarmos uma tabela a ela mesma com a utilização de apelidos,
permitindo juntar tuplas da tabela a outra tuplas da mesma tabela.
SELECT A.EMPNUME, A.EMPNOME, A.EMPSERV, B.EMPNOME
FROM EMP A, EMP B
WHERE A.EMPGERE = B.EMPNUME;
As Sub-Consultas
Uma sub-consulta é um comando "select" que é aninhado dentro de outro "select" e
que devolve resultados intermediários.
20) Relacione todos os nomes de funcionários e seus respectivos cargos, desde
que o orçamento do departamento seja igual a 300000.
Resp:
SELECT EMPNOME, EMPSERV
FROM EMP A
WHERE 300000 IN ( SELECT DEPORCA
FROM DEPT
WHERE DEPT.DEPNUME = A.DEPNUME );
Nota: Observe que a cláusula IN torna-se verdadeira quando o atributo indicado está
presente no conjunto obtido através da subconsulta.
21) Relacione todos os departamentos que possuem empregados com
remuneração maior que 3500.
Resp:
SELECT DEPNOME
FROM DEPT A
WHERE EXISTS (SELECT *
FROM EMP
WHERE EMPSALA > 3500 AND EMP.DEPNUME =
A.DEPNUME');
Nota: Observe que a cláusula EXISTS indica se o resultado de uma pesquisa contém
ou não tuplas. Observe também que poderemos verificar a não existência (NOT
EXISTS) caso esta alternativa seja mais conveniente.
59
Uniões
Podemos eventualmente unir duas linhas de consultas simplesmente utilizando a
palavra reservada UNION.
22) Liste todos os empregados que tenham códigos > 10 ou Funcionários que
trabalhem em departamentos com código maior que 10.
Resp: Poderíamos resolver esta pesquisa com um único Select, porém devido ao fato
de estarmos trabalhando em nosso exemplo com apenas duas tabelas não
conseguimos criar um exemplo muito adequado para utilização deste recurso.
(Select *
From Emp
Where EmpNume > 10)
Union
(Select *
From Emp
Where DepNume > 10);
Inserções, Alterações e Exclusões
Uma linguagem direcionada a extração de informações de um conjunto de dados, em
tese não deveria incorporar comandos de manipulação dos dados. Devemos observar
contudo que a mera existência de uma linguagem padronizada para acesso aos dados
"convidava" os desenvolvedores a aderirem a uma linguagem "padrão" de manipulação
de tabelas. Naturalmente cada desenvolvedor coloca "um algo mais" em seu SQL (SQL
PLUS, SQL *, ISQL, e toda sorte de nomenclaturas), por um lado desvirtuando os
objetivos da linguagem (padronização absoluta), mas em contrapartida otimiza os
acessos ao seu banco de dados e por maior que sejam estas mudanças, jamais são
tão importantes que impeçam que um programador versado em SQL tenha grandes
dificuldades em se adaptar ao padrão de determinada implementação. De fato as
diferenças entre o SQL da Sybase, Oracle, Microsoft, são muito menores dos que as
existentes entre o C, o BASIC e o Pascal, que são chamadas de linguagens "irmãs",
pois todas se originam conceitualmente no FORTRAN. Podemos observar que todas
as três linguagens mencionadas possuem estruturas de controle tipo "para" (for),
"enquanto" (while) e repita (do..while, repeat..until). Todas trabalham com blocos de
instrução, todas tem regras semelhantes para declaração de variáveis e todas usam
comandos de tomada decisão baseadas em instruções do tipo "se" ou "caso", porém
apesar de tantas semelhanças (sic), é praticamente impossível que um programador
excelente em uma linguagem consiga rapidamente ser excelente em outra linguagem
do grupo. Poderíamos arriscar a dizer que um excelente programador C que utilize a
implementação da Symantech terá que passar por um breve período de adaptação
para adaptar-se ao C da Microsoft.
O que ocorreria então se este programador tiver que se adaptar ao Delphi (Pascal) da
Borland?
60
De forma alguma o mesmo ocorrerá com o especialista em SQL ao ter que migrar do
Banco de Dados X para o Banco de Dados Y. Naturalmente existirá a necessidade de
aprendizado, mas este programador poderá ir adaptando-se aos poucos sem precisar
ser retreinado, o que é um aspecto extremamente vantajoso para as empresas.
Inserir (Insert)
INSERT INTO <tabela> [<campos>] [VALUES <valores>]
Ex:
INSERT INTO DEPT;
Possibilita a inserção de registros de forma interativa.
INSERT
INTO
DEPT
(DEPNUME,DEPNOME,DEPLOCA)
(70,"PRODUCAO","RIO DE JANEIRO");
Possibilita a inserção de registros em tabelas sem digitação dos dados.
VALUES
Atualizar (Update)
UPDATE <tabela> SET <campo> = <expressão> [WHERE <condição>];
Ex:
UPDATE EMP SET EMPSALA = EMPSALA* 1.2 WHERE EMPSALA< 1000;
Excluir (Delete)
DELETE FROM <tabela> [WHERE <condição>];
Ex:
DELETE FROM emp WHERE EMPSALA > 5000;
Transações
Muitas vezes gostaríamos que determinado processo, caso fosse abortado por
qualquer motivo, pudesse ser inteiramente cancelado. Imaginemos por exemplo um
usuário digitando um pedido. Imaginemos ainda que o sistema possa reservar cada
item solicitado de maneira "on line", ou seja ao mesmo tempo em que estou digitando a
quantidade o sistema já "empenhe" uma quantidade equivalente no estoque.
Imaginemos ainda que o sistema deve cancelar todas as operações se apenas um dos
itens não puder ser atendido. Grande problema, caso não pudéssemos anular todos os
processos a partir de determinada condição.
61
Vamos simular tal ocorrência com nosso banco de dados EMP. Imaginemos que ao
invés de digitarmos DELETE FROM emp WHERE salário > 5000; tivéssemos digitado
DELETE FROM emp WHERE salário > 500; Ao invés de eliminarmos 2 registros,
praticamente teríamos eliminado o banco de dados todo. Para evitarmos que um erro
de digitação, ou um processo iniciado porém sem condição de ser completado
integralmente comprometa todos nossos dados podemos criar uma transação que nos
assegurará que nossos testes sejam bem sucedidos ou cancelados sem comprometer
nossos dados.
begin transaction;
delete from emp where salário > 500;
if SQL_RECORDCOUNT > 20 THEN;
ROLLBACK TRASACTION;
else
COMMIT;
endif;
end transaction;
Visões
Uma visão consiste basicamente de uma tabela derivada de outras tabelas.
Considerando o exemplo TRABALHO, poderíamos criar uma visão baseada na Tabela
de Empregados (EMP) e na Tabela de Departamentos (DEPT) onde tivéssemos
somente os Nomes dos Funcionários e os Departamentos nos quais estes
trabalhassem. Teríamos algo assemelhado ao abaixo representado
CREATE VIEW EMP_DEP
AS SELECT E.EMPNOME, D.DEPNOME
FROM EMP E, DEPT D
WHERE E.DEPNUME = D.DEPNUME;
Devemos observar que:
1- Uma visão definida sobre uma única tabela somente será atualizável se os atributos
da tal visão contiverem a chave primária de tal tabela.
2- Visões sobre várias tabelas não são passíveis de atualizações.
3- Visões que se utilizam de funções de agrupamentos, também não poderão ser
atualizadas.
62
Download

Informática básica: Sistema operacional Microsoft Windows XP