Olá comunidade, peço ajuda pra quem trabalha com Postgres em
ambiente Linux e que também escreve Shell-scripts.
Preciso fazer uma rotina de backup de uma base em Postgresql 8.2.4.
Existem centenas de tabelas na base; todas as tabelas estão no formato bhXXX_h_YYYY_MM_DD,
onde XXX é o rótulo de um tipo de tabela e YYYY_MM_DD refere-se à data de criação da tabela.
Eis exemplos: bheqp_h_2009_01_09, bhmul_h_2009_01_09 , bhpas_h_2009_01_09, bhpds_h_2009_01_09, etc.
Fiz uma cópia de dados de uma tabela do servidor através do pgAdmin e obtive o seguinte comando:
pg_dump.exe --host 10.98.0.83 --port 5432 --username sage
--format plain --data-only --verbose --file "C:\teste.sql" --table "\"public\".\"bheqp_h_2009_01_09\"" bhcolsl_ems_sage
Preciso fazer um programa/script para rodar , que o usuário entre com a data inicial e final e execute o comando acima
de acordo com os parâmetros das datas; O arquivo gerado tem que ter o mesmo nome da tabela copiada.
Seria algo assim como o pseudo-codigo abaixo:
---------------------------------------
./copy_tabelas 2010-01-01 2010-01-31
---------------------------------------
tipos_tabelas[] = { ‘mul’, ‘eqp’, ‘pas’, ‘pds’, ‘lia’ };
For (i=0; i < tipos_tabelas.lenght; i++) {
data_aux = data_inicial;
While (data_aux <= data_final) {
Nome_arquivo = data_aux || ‘.dados’;
EXCUTAR pg_dump.exe --host 10.98.0.83 --port 5432 --username sage
--format plain --data-only --verbose --file "<< Nome_arquivo >>" --table "\"public\".\"bheqp_h_<<data_aux>>\"" bhcolsl_ems_sage
data_aux = data_aux + 1;
}
}
Eu gostaria de saber como fazer isso em Shell-script. Se alguém puder dar um help.
Desde já agradeço. Att.
NEWTON TEIXEIRA DO N. JR.