Você está na página 1de 8

IMPLEMENTAO DO BANCO DE DADOS COM POSTGRESQL

(Modelo Fsico)
Softwares free de Modelagem e Gerenciamento do PostgreSQL
Stand-Alones
- PGAdmin (http://www.postgresql.org/ftp/pgadmin3/release/)
- EMS (http://www.sqlmanager.net/en/products/postgresql/manager/download)
- DBDesigner (http://fabforce.net/downloads.php)
- Aqua Data Studio (http://www.aquafold.com/)
- DbVisualizer http://www.dbvis.com/products/dbvis/
- Gaud (http://sourceforge.net/projects/gaudi)
- Open Office Base
Em forma de Plug-ins para Eclipse
- QuantumDB (http://quantum.sourceforge.net/)
- Azzurri (http://www.azzurri.jp/en/software/clay/download.jsp)
- SQLExplorer (http://sourceforge.net/projects/eclipsesql)
Frente aos SGBDRs existentes selecionar um ou mais que melhor se adaptem s necessidades do
cliente.
Uma grande e boa relao de softwares de projeto, modelagem e gerenciamento para o PostgreSQL,
free e comercial pode ser encontrada em no site oficial so PostgreSQL Brasil:
https://wiki.postgresql.org.br/wiki/Ferramentas.
Suporte Acentuao na Criao de Bancos no PostgreSQL
A codificao default do PG 7.X a SQL_ASCII
A do PG 8.X a UNICODE
Ambas tem suporte a acentuao, mas geram problemas no backup/importao.
Para um suporte estvel acentuao em portugus do Brasil uma boa opo
criar o banco passando a codificao (Encoding) LATIN1
ENCODING = 'LATIN1'
Criao do Banco
Criaremos o banco do projeto de testes com o PGAdmin, contendo esquemas, tabelas, views,
funes do tipo SQL e Pl/PgSQL, usurios, privilgios, consultas, etc. para ilustrar nosso projeto e
servir de base para os testes (em seguida).
Analisar o modelo sugerido e detalhar o banco, tipos de dados de cada campo, tamanho, esquemas
do banco, usurios e senhas, privilgios de cada um (cuidados com a segurana), etc.
Ativar o Suporte s Funes Pl/Pgsql (Stored Procedures)
Aps ter criado o banco, podemos ativar o suporte a plpgsql.
Ativar suporte a Pl/PgSQL requer dois passos:
- instalar a biblioteca Pl/PgSQL, que do tipo contrib
- definir a linguagem (como sugerido abaixo)
- Ativando na console do PG depois de conectar ao banco onde ficar o suporte:
CREATE LANGUAGE 'plpgsql' HANDLER plpgsql_call_handler LANCOMPILER 'PL/pgSQL'
- Ativando como superusurio na console (fora dos bancos)
cd /usr/local/pgsql/bin/
$ createlang plpgsql -U nomesuperuser nomebanco
Ou simplesmente:
$ createlang plpgsql nomebanco
JDBC
Quando instalamos o PostgreSQL 8 ele j traz o JDBC, que fica em um dos seus
subdiretrios. Alguns programas em Java o utiliza, como o plugin QuantumDB.
Esquemas
Definir os esquemas do banco.
Quando o cliente precisa de muitas tabelas, organizadas em vrias reas a sada imdeiata a criao
de vrios bancos de dados. Mas quando da implementao do aplicativo que ir utilizar estes bancos
os desenvolvedores se depararo com a dificuldade de comunicao e acesso entre os bancos, j que
com uma nica conexo tero acesso a todos os objetos do banco. muito til para estes casos criar
um nico banco e neste criar vrios esquemas, organizados por reas: pessoal, administracao,
contabilidade, engrnharia, etc.
Mas e quando uma destas reas tem outras sub-reas, como por exemplo a engenharia, que tem
reservatrorios, obras, custos ecada um destes tem diversas tabelas. O esquema engenharia ficar
muito desorganizado. Em termos de organizao o ideal seria criar um banco para cada rea,
engenharia, contabilidade, administrao, etc. E para engenharia, por exemplo, criar esquemas para
cada subarea, custos, obras, etc. Mas no o ideal em termos de comunicao e acesso entre todos os
bancos. J que os esquemas no PostgreSQL ainda no suportam subesquemas, uma sugesto criar
vrios esquemas para a engenharia e todos com o prefixo engenharia_. Ento teramos
engenharia_reservatorios, engenharia_obras, engenharia_custos, etc.
Criar Esquema
Num gerenciador do PG entra-se no banco e nesse cria-se o esquema.
Ou
CREATE SCHEMA nomeesquema;
Acessando Objetos de Esquemas
Para acessar um esquema devemos passar seu caminho:
nomeesquema.nometabela
Ou
nomebanco. nomeesquema.nometabela
Criando Tabela em Esquema
CREATE TABLE nomeesquema.nometabela (
...
)
Criando Esquema e tornando um Usurio seu dono
CREATE SCHEMA nomeesquema AUTHORIZATION nomeusuario;
Removendo privilgios de acesso a usurio em esquema
REVOKE CREATE ON SCHEMA public FROM PUBLIC
Com isso estamos tirando o privilgio de todos os usurios acessarem o esquema public.
Acesso aos Esquemas
Quando se cria um banco no PostgreSQL, por default, ele cria um esquema pblico (public) no
mesmo e neste esquema que so criados todos os objetos quando no especificamos o esquema. A
este esquema public todos os usurios do banco tm livre acesso, mas aos demais existe a
necessidade de se dar permisso para que os mesmos acessem.
Tabelas
O PostgreSQL permite adicionar privilgios por objeto do banco: tabela, esquema, banco, etc. Em
termos de segurana importante, em geral, que os privilgios sejam adicionados ao usurio por
tabela, cada tabela tendo um dono e cada dono tendo seus especficos privilgios.
Dica de Desempenho: Na criao das tabelas alertar para a criao de ndices para os campos
envolvidos na clusula WHERE. Isso tornar essas consultas mais rpidas.
Views
Juntamente com as funes armazenadas (stored procedures) as views so boas alternativas para
tornar o cdigo mais simples e o aplicativo mais eficiente, j que parte do processamento feito pelo
cdigo agora j est pronto e debugado no banco.
Dica: para uso de views, sintaxe de funes internas e uso de clusulas SQL no PostgreSQL,
tutoriais de EMS e vrios outros sobre PostgreSQL, alm de PHP, JavaScript, etc, confira a seo de
downlowds do site abaixo:
http://ribafs.byethost2.com ou
http://ribafs.tk
CRIAO DO BANCO
Tutorial sobre PGAdmin para criar o banco funcionarios.
Bem, de posse do script .sql acima, praticamente o que teremos de fazer criar um banco vazio no
PGAdmin.
Abra o PGAdmin
Caso no tenha salvado a senha ele pedir sempre que iniciar
Ao abrir clique com o boto direito direita em Databases e em New Database.
- No dilogo New Database entre com o Name do banco (funcionarios), o Owner (postgres).
Idealmente mudar o nome do superusuario default para um nome mais seguro, assim como a senha
(mnimo de 8 caracteres, misturando letras e algarismos e idealmente com smbolos).
Tambm altere Encoding (codificao) para LATIN1 e OK.
- Ento selecione o banco funcionarios e clique no boto SQL acima.
- Clique no boto open file para indicar o nosso script sql gerado anteriormente.
- Clique na setinha verde (Execute query)
Eventuais Correes:
Caso receba mensagens de erro sobre tipo UNSIGNED, verifique o script e remova todas as
ocorrncias de UNSIGNED e execute novamente. Como o DBDesigner foi projetado para o
MySQL um outro erro que pode ocorrer com a string AUTO_INCREMENT, que tambm deve ser
removida e novamente devemos executar o script. Feitas estas correes o script executa
normalmente e cria o nosso banco funcionarios.
Ento verifique esquerda que o banco j contm as 3 tabelas de acordo com o script.
Engenharia Reversa
Um timo software para conexo ao PostgreSQL, engenharia reversa (gera diagramas ER dos
bancos existentes) e exporta os diagramas em forma de imagens: DbVisualizer.
Ribamar FS http://ribafs.tk ribafs[]gmail.com
23/01/2006

Você também pode gostar