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