<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="pt-BR">
	<id>https://wiki.ourominas.com.br/index.php?action=history&amp;feed=atom&amp;title=Trigger_no_Oracle</id>
	<title>Trigger no Oracle - Histórico de revisão</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.ourominas.com.br/index.php?action=history&amp;feed=atom&amp;title=Trigger_no_Oracle"/>
	<link rel="alternate" type="text/html" href="https://wiki.ourominas.com.br/index.php?title=Trigger_no_Oracle&amp;action=history"/>
	<updated>2026-04-17T12:44:34Z</updated>
	<subtitle>Histórico de revisões para esta página neste wiki</subtitle>
	<generator>MediaWiki 1.45.1</generator>
	<entry>
		<id>https://wiki.ourominas.com.br/index.php?title=Trigger_no_Oracle&amp;diff=1629&amp;oldid=prev</id>
		<title>imported&gt;Admin: uma edição</title>
		<link rel="alternate" type="text/html" href="https://wiki.ourominas.com.br/index.php?title=Trigger_no_Oracle&amp;diff=1629&amp;oldid=prev"/>
		<updated>2020-08-08T03:12:53Z</updated>

		<summary type="html">&lt;p&gt;uma edição&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;pt-BR&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Edição anterior&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Edição das 03h12min de 8 de agosto de 2020&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;4&quot; class=&quot;diff-notice&quot; lang=&quot;pt-BR&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(Sem diferença)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;
&lt;!-- diff cache key omph_wiki-maquine_:diff:1.41:old-1628:rev-1629 --&gt;
&lt;/table&gt;</summary>
		<author><name>imported&gt;Admin</name></author>
	</entry>
	<entry>
		<id>https://wiki.ourominas.com.br/index.php?title=Trigger_no_Oracle&amp;diff=1628&amp;oldid=prev</id>
		<title>2532252&gt;Jefferson em 17h40min de 28 de janeiro de 2019</title>
		<link rel="alternate" type="text/html" href="https://wiki.ourominas.com.br/index.php?title=Trigger_no_Oracle&amp;diff=1628&amp;oldid=prev"/>
		<updated>2019-01-28T17:40:58Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Página nova&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Informação retirada de&lt;br /&gt;
&lt;br /&gt;
https://terminaldeinformacao.com/2014/04/01/criando-triggers-no-oracle/&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
CRIANDO TRIGGERS NO ORACLE&lt;br /&gt;
 Abril 1, 2014  Dan_Atilio Comments  2 Comments&lt;br /&gt;
Olá pessoal…&lt;br /&gt;
&lt;br /&gt;
Hoje irei falar um pouco sobre Triggers (Gatilhos) em Oracle, qual a sua funcionalidade e como criar.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 &lt;br /&gt;
Mas o que seria Triggers? Simplesmente são Gatilhos acionados por ações de usuários, por exemplo, ao criar algum registro, atualize tais dados, ou ao excluir, atualize outra tabela. Enfim, basicamente é uma ação disparada por uma outra ação (ex.: ao incluir, faça algo).&lt;br /&gt;
&lt;br /&gt;
Um bom exemplo seria, ao aumentar o salário de uma pessoa, gravar um log com o salário antigo. Esse exemplo que será demonstrado abaixo, primeiramente iremos criar uma tabela de logs, onde qualquer alteração em salários (da tabela padrão EMPLOYEES), irá gerar um registro de Log.&lt;br /&gt;
Abaixo, o script para criação da tabela de Logs.&lt;br /&gt;
&lt;br /&gt;
Criando tabela de logs:&lt;br /&gt;
&lt;br /&gt;
CREATE TABLE  Y_LOG (&lt;br /&gt;
  ID_LOG          NUMBER(08)   NOT NULL   PRIMARY KEY,&lt;br /&gt;
  DATA_LOG        DATE         NOT NULL,&lt;br /&gt;
  SALARIO_ANT     NUMBER(08,2) NOT NULL,&lt;br /&gt;
  SALARIO_NOV     NUMBER(08,2) NOT NULL,  &lt;br /&gt;
  ID_FUNC         NUMBER(06)   NOT NULL&lt;br /&gt;
);&lt;br /&gt;
Criando sequência de incremento (dúvidas, leia Criando Sequences no Oracle):&lt;br /&gt;
&lt;br /&gt;
CREATE SEQUENCE SEQ_LOG&lt;br /&gt;
  START WITH 1&lt;br /&gt;
  INCREMENT BY 1&lt;br /&gt;
  MAXVALUE 999999999&lt;br /&gt;
  MINVALUE 1&lt;br /&gt;
  NOCACHE&lt;br /&gt;
  NOCYCLE;&lt;br /&gt;
Criando Gatilho (que define antes ou depois de qual ação – BEFORE ou AFTER, de qual campo – OF, em qual tabela – ON, e para cada linha – FOR EACH ROW):&lt;br /&gt;
&lt;br /&gt;
CREATE OR REPLACE TRIGGER VERIF_SALARIO&lt;br /&gt;
  BEFORE UPDATE&lt;br /&gt;
  OF SALARY&lt;br /&gt;
  ON EMPLOYEES&lt;br /&gt;
  FOR EACH ROW&lt;br /&gt;
  BEGIN&lt;br /&gt;
  insert into Y_LOG values (    SEQ_LOG.NEXTVAL,&lt;br /&gt;
                SYSDATE,&lt;br /&gt;
                :old.SALARY,&lt;br /&gt;
                :new.SALARY,&lt;br /&gt;
                :old.EMPLOYEE_ID);&lt;br /&gt;
END;&lt;br /&gt;
Não esqueça de salvar os dados.&lt;br /&gt;
&lt;br /&gt;
COMMIT;&lt;br /&gt;
Atualizando tabela para criação de Gatilho:&lt;br /&gt;
&lt;br /&gt;
UPDATE EMPLOYEES SET SALARY=24000 WHERE EMPLOYEE_ID=100;&lt;br /&gt;
Resultado:&lt;br /&gt;
&lt;br /&gt;
Resultado&lt;br /&gt;
Resultado&lt;br /&gt;
É possível até fazer tratamentos, como no exemplo abaixo, onde é criado uma trigger para tabela de notas, e gravando se é exclusão ou alteração:&lt;br /&gt;
&lt;br /&gt;
--Trigger&lt;br /&gt;
CREATE OR REPLACE TRIGGER A_TRIG_NOTA&lt;br /&gt;
  BEFORE DELETE OR UPDATE &lt;br /&gt;
  OF VALOR_NOTA ON A_NOTA&lt;br /&gt;
  FOR EACH ROW&lt;br /&gt;
DECLARE&lt;br /&gt;
    cTipo VARCHAR(6);&lt;br /&gt;
BEGIN&lt;br /&gt;
&lt;br /&gt;
    --Update  &lt;br /&gt;
    IF updating THEN&lt;br /&gt;
      cTipo:=&amp;#039;UPDATE&amp;#039;;&lt;br /&gt;
    END IF;&lt;br /&gt;
&lt;br /&gt;
    --Delete&lt;br /&gt;
    IF deleting THEN&lt;br /&gt;
      cTipo:=&amp;#039;DELETE&amp;#039;;&lt;br /&gt;
    END IF;&lt;br /&gt;
&lt;br /&gt;
    --Inserindo dados&lt;br /&gt;
    insert into A_NOTA_LOG values ( A_SEQ_LOG.NEXTVAL,&lt;br /&gt;
                                    :old.RA,&lt;br /&gt;
                                    :old.COD_CURSO,&lt;br /&gt;
                                    :old.COD_DISC,&lt;br /&gt;
                                    :old.SEMESTRE_ANO,&lt;br /&gt;
                                    :old.SEQ_NOTA,&lt;br /&gt;
                                    :old.VALOR_NOTA,&lt;br /&gt;
                                    :new.VALOR_NOTA,&lt;br /&gt;
                                    SYSDATE,&lt;br /&gt;
                                    cTipo);&lt;br /&gt;
END;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Category: ORACLE]]&lt;br /&gt;
[[Category: TRIGGER]]&lt;/div&gt;</summary>
		<author><name>2532252&gt;Jefferson</name></author>
	</entry>
</feed>