Pular para o conteúdo principal

Manipular arquivos com PL/SQL (Oracle)

papelO bom e velho arquivo, é impressionante como lidamos com seus vários tipos durante todos os dias, bom hoje vamos mostrar um jeito simples de se escrever e ler arquivos apenas com a codificação nativa do Oracle.

A primeira coisa a fazer é criar um diretório válido configurado no Oracle, e permissões de acesso a esse diretório para o usuário de banco onde faremos o exemplo, sendo assim suponhamos que nosso usuário de banco se chame programero, e nosso diretório real esteja em c:\programero, então logado como SYSTEM devemos executar os seguintes comandos:

  1: -- cria diretorio   
  2: create or replace directory DIR_PROGRAMERO as 'C:\PROGRAMERO';   
  3: -- concede permissão de escrita e leitura para nosso usuário   
  4: grant read, write on directory DIR_PROGRAMERO to PROGRAMERO;

Para escrever, basicamente precisamos apenas saber onde esse arquivo ficará, no nosso caso no diretório criado acima, segue o código de escrita:

  1: declare
  2:   -- nosso handler
  3:   v_arq utl_file.file_type;
  4: begin
  5:   -- diretório oracle, nome do arquivo, w indica escrita
  6:   v_arq := utl_file.fopen('DIR_PROGRAMERO' , 'programero.txt', 'w'); 
  7:   -- escrevemos duas linhas no arquivo
  8:   utl_file.put_line(v_arq,'Primeira linha !'); 
  9:   utl_file.put_line(v_arq,'Segunda linha !'); 
 10:   -- e finalmente fechamos o arquivo
 11:   utl_file.fclose(v_arq);
 12: end;

Da mesma maneira a escrita também depende do local onde o arquivo está salvo, segue o código:
  1: declare
  2:   -- nosso handler
  3:   v_arq utl_file.file_type;
  4:   -- recebe a linha lida do arquivo
  5:   v_txt varchar2(200);
  6: begin
  7:   -- diretório oracle, nome do arquivo, r indica leitura
  8:   v_arq := utl_file.fopen('DIR_PROGRAMERO' , 'programero.txt', 'r'); 
  9:   -- loop de leitura
 10:   loop
 11:     -- pega linha do arquivo
 12:     utl_file.get_line(v_arq, v_txt);
 13:     -- imprime
 14:     dbms_output.put_line(v_txt);
 15:   end loop;
 16: exception  
 17:   when NO_DATA_FOUND then
 18:     -- quando não existirem mais linhas no arquivo o mesmo é fechado
 19:     utl_file.fclose(v_arq);
 20: end;

Bom é isso, os códigos são simples e estão bem comentados, acredito que não exista nada a ser acrescentado, no caso de dúvidas é só postar nos comentários.

Comentários

  1. Ola Eduardo, apos a inserçao do arquivo no banco de dados, teria como manipula-lo ? Tipo mala-direta, onde teria uma carta padrão, com algums campos oriundos de uma tabela oracle, como nome, enderço, e a partir de uma chamada (talvez um report) fazer a impressão deste documento preenchido.

    ResponderExcluir
  2. Estou pesquisando como realizar um LOOP em um diretorio e ler todos os arquivos que estejam iniciados com um prefixo "x" exemplo: "ARQUIVO*.*"

    Porém, não consegui localizar ainda como abrir o arquivo, uma vez que o utl_file.fopen espera o nome exato do arquivo que será aberto.

    Cada arquivo sera tratado individualmente e apos a leitura sera transferido para outro diretorio, permitindo que o loop funcione até que nao exista mais nenhum arquivo com este nome no diretorio.


    Pode me ajudar?

    Obrigada!

    ResponderExcluir
    Respostas
    1. Olá Maria Fernanda, pelo PL/SQL não é possível listar arquivos dentro de um diretório, isso só é possível por meio do Java.

      Excluir
  3. Parabéns. Me ajudou. Muito bem explicado.

    ResponderExcluir

Postar um comentário

Obrigado por Participar do programero, fique a vontade para agradecer, retificar, perguntar ou sugerir.

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;   //   // temp char pointer   psTemp : PChar;   //   // check point   dwChkP : DWord; begin   ss.dwCurrentState := -1;   //

Funções de Data e Hora (Delphi)

É muito comum nos depararmos no dia a dia com a necessidade de manipular datas e horas, seja para um calculo de permanência, dias de atraso enfim, é praticamente escapar de alguma situação que necessite desse tipo de controle. Assim como a necessidade e se utilizar algum recurso para manipular as datas e horas de alguma maneira e freqüente, as duvidas de como o faze-lo também é, basta um breve olhar em qualquer fórum especializado e lá está, alguma duvida relacionada, por isso decidi falar um pouco sobre uma unit muito poderosa chamada DateUtils para a manipulação de data e hora, com um grande numero de métodos e classes que facilitam a vida de qualquer um. Alguns exemplos: CompareDate(constA, B: TDateTime): TValueRelationship; Compara apenas a data de dois valores (do tipo TDateTime) retornando: LessThanValue O primeiro valor é menor que o segundo EqualsValue Os valores são iguais GreaterThanValue O primeiro valor é maior que o segundo CompareDateTime(const A, B: TD