Jump to content
mlgrassi

Como fazer um PL/SQL limitando o número de commits executando um arquivo .sql contendo inserts?

Recommended Posts

Prezados,

 

Tenho uma situação onde preciso criar um pl/sql que limite o número de comits para o sql executado. O problema é que a entrada é um arquivo sql pronto contendo inserts. Como poderia fazer isso? Desculpem, sou iniciante.

Share this post


Link to post
Share on other sites

Editar o arquivo é o mais simples , por limitar você diz um COMMIT a cada x INSERTS , não ?

Share this post


Link to post
Share on other sites

Sim, isso mesmo Motta.
 

O pl/sql irá executar em ambiente linux, logo, recebo o arquivo de inserts.sql e conto suas linhas para saber quantos inserts terá no total. Depois, preciso executar esse lote de inserts e ao final preciso que retorne o número de commits executados com sucesso e a parte disso, os que não executaram por algum erro. Assim, posso fazer um batimento comparando o total com aquilo que foi comitado com sucesso.

 

Alguma dica sobre como eu poderia fazer?

Share this post


Link to post
Share on other sites

O INSERT é executado ou não , se o BD acatar a síntaxe e as validações que existirem (constraints , trigers etc) o INSERT é feito ,

 

o COMMIT é o comando que faz com que as alterações que estão válidas para sua sessão fiquem válidas para todo o BD.

 

Estamos falando de coisas diferentes creio.

 

Publique um exemplo do arquivo se possível.

Share this post


Link to post
Share on other sites

Boa tarde,

 

Dependendo de como você estiver executando os inserts, você pode setar o autocommit

 

create table teste(
Id_teste number(12));


set autocommit 10


insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
insert into teste (id_teste) values(1);
 

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By cfreis01
      eu tenho uma tabela  funcionário com uma coluna salário e criei uma nova coluna do tipo salário eu pensei em uma trigger
      para que todas as vezes que um funcionário receba um aumento, nessa nova coluna seja registrada a quantia do último aumento recebido
      mas quando executo o update da erro;
      outra duvida dentro do update como o update sabe que é só deste  funcionario? o que colocar na clausula where dentro da trigger?
      CREATE OR REPLACE TRIGGER new_salario_emp BEFORE UPDATE ON emp FOR EACH ROW -- DECLARE salario number; BEGIN salario := :new.sal - :OLD.sal; -- update emp set old_salario = salario; commit; -- END;  
    • By sadamkim
      Pessoal,  me deparei com um problema.
      Tenho uma Tabela, onde fica armazenada as transações dos clientes.
      Cada transação tem vários registros com o campo STATUS.
       
      Preciso fazer um MAX, para pegar a ultima transação por data, e assim saber qual foi o status da mesma.
      Mas ao utilizar o MAX e selecionar o campo STATUS ele me traz todos os registro, porque o mesmo não pode agrupar por status, por conter valores diferentes.
      É possível criar alguma forma de selecionar no meu caso a ultima transação por data (MAX) e trazer o campo status?
      Seja com alguma procedure, ou outra função do ORACLE.


    • By douglas.ribeiro.id
      Bom dia a todos
       
      a varios anos que nao tenho que criar um script no oracle nao consigo lembrar ne como começar e tambem estou sem o oracle instalado na maquina
      alguem poderia me ajudar? o problema e este: 
      Crie um segundo script (SCRIPT2.SQL) que possua um bloco de código para que gere registros fictícios para as tabelas criadas. Gere 1000 registros para a tabela EXAME_NF. Para cada EXAME_NF gere 3 registros. Faça com que a DATACADASTRO do EXAME_NF comece em 10 dias atrás, fazendo com que a cada 100 registros a data seja aumentada em 1 dia, distribuindo assim os 1000 registros em 10 dias diferentes de cadastro.
    • By pamf
      Prezados, boa noite!
       
      Me deparei com um problema aqui que acredito que seja bem simples para voces. Estou aqui precisando agrupar dados com a maior data de vendas para um cliente Numa coluna para todas as linhas do cliente (registro a registro das notas). Tambem preciso fazer algumas operacoes de total para disponibilizar um SCRIPT SQL sql para ser consumido por uma ferramenta analitica de BI e foi especificado exatamente como esta na planilha. Para facilitar criei os cenários. Tem os scripts de criacao da tabela e de insert e os resultados esperados nas colunas calculadas pelo sql. Espero que a documentação esteja boa para o caso de uso e que voces possam me ajudar. POde ser didatico para quem da aulas de PL SQL.
       
      Grato
       
      Att
      Paulo
       
      PS: como nao aceitou a planilha, escrevo abaixo:
       
      --SCRIPT DE CRIACAO TABELA ORACLE CREATE TABLE T_VENDAS (DATA_VENDA DATE, COD_CLI NUMBER (10), CLIENTE VARCHAR2(10), NUM_NF VARCHAR(10), ITEM VARCHAR2(20), QTDE NUMBER (10,2), VL_TOT_ITEM NUMBER (10,2), VL_UNIT NUMBER (10,2)); --INSERTS INSERT INTO T_VENDAS VALUES('05-Jan-2019',15,'JOAO','20','MESA',1,200,200); INSERT INTO T_VENDAS VALUES('05-Jan-2019',15,'JOAO','20','CADEIRA',4,240,60); INSERT INTO T_VENDAS VALUES('21-Jan-2019',15,'JOAO','66','BANCO',2,240,120); INSERT INTO T_VENDAS VALUES('08-Feb-2019',15,'JOAO','102','GELADEIRA',1,600,600); INSERT INTO T_VENDAS VALUES('07-Mar-2019',15,'JOAO','145','ARMARIO',1,450,450); INSERT INTO T_VENDAS VALUES('05-Jan-2019',20,'MARIA','28','SOFA',1,750,750); INSERT INTO T_VENDAS VALUES('05-Jan-2019',20,'MARIA','28','TAPETE',2,280,140); INSERT INTO T_VENDAS VALUES('21-Jan-2019',20,'MARIA','72','CORTINA',2,160,80); INSERT INTO T_VENDAS VALUES('08-Feb-2019',20,'MARIA','120','CAMA',1,400,400); INSERT INTO T_VENDAS VALUES('17-Feb-2019',20,'MARIA','151','COLCHAO',1,500,500);  
       
      CENARIOS (DADOS INSERIDOS NA TABELA T_VENDAS - COLUNAS DO EXCEL ABAIXO: B, C, D, E, F, G, H, I)
       

       
      COLUNAS CALCULADAS ESPERADAS NO SCRIPT SQL ALEM DAS COLUNAS JA EXISTENTES NA TABELA
       

       
      RESULTADO ESPERADO DO SCRIPT SQL
       

       
       
       
         
    • By EREGON
      Bom dia,
       
      tenho uma tabela cuja estrutura está toda em VARCHAR. Essa tabela contem algumas colunas com valores decimais, e quero executar algumas queries para fazer algumas operações aritméticas, como:
       
      -Devolver valores maiores que xx.xx, etc.
       
      Mas estou a ter erros, como:
       
      ORA-12801: erro assinalado no servidor de consulta paralela P009, instance ptlhb100.pt.sedc.internal.vodafone.com:CSTMRDM2 (2)
      ORA-01722: número inválido
      12801. 00000 -  "error signaled in parallel query server %s"
      *Cause:    A parallel query server reached an exception condition.
      *Action:   Check the following error message for the cause, and consult
                 your error manual for the appropriate action.
      *Comment:  This error can be turned off with event 10397, in which
                 case the server's actual error is signaled instead.
       
      Estou a executar a querie:
       
      SELECT TBL_NUMBER
      FROM MOBILE_UPSELL tl
      WHERE TO_NUMBER(tl.ARPU_MIB) < 8.01
       
      Já tentei TO_BINARY_NUMBER e dá o mesmo erro.
       
      O que está mal aqui?
       
      Obrigado
       
      Paulo
       
       
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.