Pular para o conteúdo principal

O que devemos conhecer sobre SQL/Oracle Parte 1: Introdução ao SQL




 

Série de postagens sobre SQL


A algum tempo atrás, não me lembro se 2009 ou 2010, comecei a escrever uma serie de artigos contendo pontos importantes sobre banco de dados, mais precisamente Oracle. Porem um descuido e uma formatação apressada fez com que eu perdesse esses artigos.
Porem recentemente, buscando uma declaração de imposto de renda, reencontrei esses artigos, a maior parte ainda esta sem formatação e outra por terminar, mas o fato de ter encontrado me deu vontade de finalizar e publicar tudo, ao todo imaginei cerca dezoito postagens abordando os mais variados tópicos. 
Começaremos hoje com um pouco de historia e um rápido resumo, espero que gostem desse e dos próximos.

Banco de dados relacionais e Dr. E. F. Codd


Antes do advento dos bancos de dados relacionais, cada desenvolvedor formulava seus próprios meios de armazenar, alterar e recuperar dados, dessa forma cada aplicação tratava a informação de um modo único, tornando a integração entre aplicações algo extremamente trabalhoso, além é claro do tempo de desenvolvimento se tornar maior.
Na década de 70 Dr. E. F. Codd desenvolveu um projeto que propunha o modelo atual de bancos de dados relacionais, onde os programadores poderiam por meio de uma linguagem padrão, comum e unificada, construir seus próprios bancos de dados.

Normalização de uma base de dados


Normalização nada mais é do que métodos que se propõe a diminuir problemas durante o uso da base de dados, como por exemplo, a construção de um modelo que não permita dados duplicados.
É importante salientar que as regras de normalização não são necessariamente objetos e sim conceitos que devem ser levados em consideração no momento da modelagem do banco, lembrando que toda base de dados que se preze deve seguir ao menos as três primeiras:

  • Primeira forma normal (1NF): Sem repetição de grupos de dados, tabelas bidimensionais;
  • Segunda forma normal (2NF): 1NF mais o fato de que cada elemento possui um identificador único (chave primária);
  • Terceira forma normal (3NF): 2NF mais o fato de que as tabelas devem possuir apenas informações referentes ao que se propõe a chave primária (informações extras devem ficar em outras tabelas);
  • Boyce-Codd (BCNF): Modificação da 3NF que elimina estruturas que possam gerar inconsistências logicas nos dados;
  • Quarta forma normal (4NF): BCNF mais logica que assegura que toda dependência multivalorada é dependente de uma superkey;
  • Quinta forma normal (5NF): 4NF mais o fato que toda junção dependente para a tabela é resultado de chaves candidatas;

Definindo e entendo o básico do SQL


A linguagem SQL é uma das mais utilizadas na atualidade, devido ao seu padrão para as bases de dados relacionais que dominam o mercado. Ela também é uma das mais poderosas, e em alguns casos também perigosa, pois permite a escrita de comandos sintaticamente corretos e logicamente errados. 
SQL significa linguagem estruturada de consulta e sobre ela podemos:
  • Criar bases de dados e objetos;
  • Armazenar dados nessa base;
  • Alterar e analisar os dados;

A base dos comandos do SQL são as palavras reservadas:
  • Select: recupera dados;
  • Insert: insere dados nas tabelas;
  • Update: atualiza dados nas tabelas;
  • Delete: remove dados das tabelas;
  • Create: cria um objeto do banco, como uma tabela, por exemplo;
  • Alter: altera um objeto do banco, como uma coluna de tabela;
  • Drop: remove um objeto do banco;

A seguir ...

Comentários

Mais visitadas

Funções de data Oracle

  Com o Oracle é possível obter uma série de resultados a partir de uma ou mais datas, como por exemplo verificar o último dia do mês ou verificar a quantidade de meses entre duas datas, então vamos a alguns exemplos:   Data atual do sistema: SYSDATE Remover meses de uma data: ADD_MONTHS(SYSDATE, -1) Adicionar meses de uma data: ADD_MONTHS(SYSDATE, +1) Buscar o último dia do mês: LAST_DAY(SYSDATE) Primeiro dia do mês: TRUNC(SYSDATE, ‘MONTH’) Quantidade de meses entre duas datas: MONTHS_BETWEEN(SYSDATE, ‘27/07/1982’) Primeiro dia do ano: TRUNC(SYSDATE, ‘YEAR’) Dias da semana: DECODE( TO_NUMBER( TO_CHAR          (SYSDATE, ‘D’) ) ,1, ‘domingo’ ,2, ‘segunda-feira’ ,3, ‘terça-feira’ ,4, ‘quarta-feira’ ,5, ‘quinta-feira’ ,6, ‘sexta-feira’ ,7,’sábado’ )

Iniciar e Parar Serviços do Windows (Delphi)

Em certas ocasiões nos deparamos com a necessidade de manipular determinadas atividades do SO, como iniciar ou parar um banco de dados, ou qualquer outro serviço que esteja funcionando no momento. Segue abaixo um código que encontrei na Internet para tal finalidade (não me recordo à fonte, assim que eu a encontrar colocarei). Iniciar Serviço: uses WinSvc; // // start service // // return TRUE if successful // // sMachine: //   machine name, ie: \SERVER //   empty = local machine // // sService //   service name, ie: Alerter // function ServiceStart(   sMachine,   sService : string ) : boolean; var   //   // service control   // manager handle   schm,   //   // service handle   schs   : SC_Handle;   //   // service status   ss     : TServiceStatus;   //   // te...

Lista de políticos com ficha suja

ATUALIZAÇÃO (08/03/2012 ano de eleição) Representantes de duas pessoas da lista (Eliseu Padilha e Alex Canziani) entraram em contato e pediram que esses fossem removidos, alegando que não houve condenação. É justo essa requisição, porém vale lembrar que escândalos nacionalmente reconhecidos de corrupção não deram em nada, por isso o que realmente conta nesse ano de eleição é uma pesquisa minuciosa sobre os candidatos escolhidos, eu particularmente, por não estar nem um pouco satisfeito, não irei votar em ninguém que já tenha sido eleito. Estou voltando a postar por um motivo nobre, meu tempo continua apertado mas esse post é rápido, na verdade nem meu ele é (visitem o espaço de nosso amigo Lord ), estou apenas repassando essa valiosa informação. Teremos eleição esse ano, e é importante não repetirmos erros passados, vamos ficar atentos em relação a esses nomes e exclui-los de vez do cenário politico nacional. Façamos nossa parte, publicando em nossos blog...