<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://sqle.ru/index.php?action=history&amp;feed=atom&amp;title=Oracle_PL%2FSQL%2FTrigger%2FTriggerable_Actions</id>
		<title>Oracle PL/SQL/Trigger/Triggerable Actions - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://sqle.ru/index.php?action=history&amp;feed=atom&amp;title=Oracle_PL%2FSQL%2FTrigger%2FTriggerable_Actions"/>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=Oracle_PL/SQL/Trigger/Triggerable_Actions&amp;action=history"/>
		<updated>2026-05-25T19:34:39Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://sqle.ru/index.php?title=Oracle_PL/SQL/Trigger/Triggerable_Actions&amp;diff=1607&amp;oldid=prev</id>
		<title> в 13:45, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=Oracle_PL/SQL/Trigger/Triggerable_Actions&amp;diff=1607&amp;oldid=prev"/>
				<updated>2010-05-26T13:45:19Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 13:45, 26 мая 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
			</entry>

	<entry>
		<id>http://sqle.ru/index.php?title=Oracle_PL/SQL/Trigger/Triggerable_Actions&amp;diff=1608&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=Oracle_PL/SQL/Trigger/Triggerable_Actions&amp;diff=1608&amp;oldid=prev"/>
				<updated>2010-05-26T09:58:20Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==Check user name in a trigger==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt; create table foo( a number );&lt;br /&gt;
Table created.&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt; create or replace trigger biud_foo&lt;br /&gt;
  2    before insert or update or delete&lt;br /&gt;
  3       on foo&lt;br /&gt;
  4  begin&lt;br /&gt;
  5    if user not in ( &amp;quot;CLBECK&amp;quot;, &amp;quot;SDILLON&amp;quot; ) then raise_application_error( -20001,&amp;quot;You do not have access to modify this table.&amp;quot; );&lt;br /&gt;
  6    end if;&lt;br /&gt;
  7  end;&lt;br /&gt;
  8  /&lt;br /&gt;
Trigger created.&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt; insert into foo (a) VALUES (1);&lt;br /&gt;
insert into foo (a) VALUES (1)&lt;br /&gt;
            *&lt;br /&gt;
ERROR at line 1:&lt;br /&gt;
ORA-20001: You do not have access to modify this table.&lt;br /&gt;
ORA-06512: at &amp;quot;sqle.BIUD_FOO&amp;quot;, line 2&lt;br /&gt;
ORA-04088: error during execution of trigger &amp;quot;sqle.BIUD_FOO&amp;quot;&lt;br /&gt;
&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt; drop table foo;&lt;br /&gt;
Table dropped.&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Log all triggerable action: iinsert, update and delete to a log table==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
SQL&amp;gt; -- create demo table&lt;br /&gt;
SQL&amp;gt; create table Employee(&lt;br /&gt;
  2    ID                 VARCHAR2(4 BYTE)         NOT NULL,&lt;br /&gt;
  3    First_Name         VARCHAR2(10 BYTE),&lt;br /&gt;
  4    Last_Name          VARCHAR2(10 BYTE),&lt;br /&gt;
  5    Start_Date         DATE,&lt;br /&gt;
  6    End_Date           DATE,&lt;br /&gt;
  7    Salary             Number(8,2),&lt;br /&gt;
  8    City               VARCHAR2(10 BYTE),&lt;br /&gt;
  9    Description        VARCHAR2(15 BYTE)&lt;br /&gt;
 10  )&lt;br /&gt;
 11  /&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt; -- prepare data&lt;br /&gt;
SQL&amp;gt; insert into Employee(ID,  First_Name, Last_Name, Start_Date,                     End_Date,                       Salary,  City,       Description)&lt;br /&gt;
  2               values (&amp;quot;01&amp;quot;,&amp;quot;Jason&amp;quot;,    &amp;quot;Martin&amp;quot;,  to_date(&amp;quot;19960725&amp;quot;,&amp;quot;YYYYMMDD&amp;quot;), to_date(&amp;quot;20060725&amp;quot;,&amp;quot;YYYYMMDD&amp;quot;), 1234.56, &amp;quot;Toronto&amp;quot;,  &amp;quot;Programmer&amp;quot;)&lt;br /&gt;
  3  /&lt;br /&gt;
SQL&amp;gt; insert into Employee(ID,  First_Name, Last_Name, Start_Date,                     End_Date,                       Salary,  City,       Description)&lt;br /&gt;
  2                values(&amp;quot;02&amp;quot;,&amp;quot;Alison&amp;quot;,   &amp;quot;Mathews&amp;quot;, to_date(&amp;quot;19760321&amp;quot;,&amp;quot;YYYYMMDD&amp;quot;), to_date(&amp;quot;19860221&amp;quot;,&amp;quot;YYYYMMDD&amp;quot;), 6661.78, &amp;quot;Vancouver&amp;quot;,&amp;quot;Tester&amp;quot;)&lt;br /&gt;
  3  /&lt;br /&gt;
SQL&amp;gt; insert into Employee(ID,  First_Name, Last_Name, Start_Date,                     End_Date,                       Salary,  City,       Description)&lt;br /&gt;
  2                values(&amp;quot;03&amp;quot;,&amp;quot;James&amp;quot;,    &amp;quot;Smith&amp;quot;,   to_date(&amp;quot;19781212&amp;quot;,&amp;quot;YYYYMMDD&amp;quot;), to_date(&amp;quot;19900315&amp;quot;,&amp;quot;YYYYMMDD&amp;quot;), 6544.78, &amp;quot;Vancouver&amp;quot;,&amp;quot;Tester&amp;quot;)&lt;br /&gt;
  3  /&lt;br /&gt;
SQL&amp;gt; insert into Employee(ID,  First_Name, Last_Name, Start_Date,                     End_Date,                       Salary,  City,       Description)&lt;br /&gt;
  2                values(&amp;quot;04&amp;quot;,&amp;quot;Celia&amp;quot;,    &amp;quot;Rice&amp;quot;,    to_date(&amp;quot;19821024&amp;quot;,&amp;quot;YYYYMMDD&amp;quot;), to_date(&amp;quot;19990421&amp;quot;,&amp;quot;YYYYMMDD&amp;quot;), 2344.78, &amp;quot;Vancouver&amp;quot;,&amp;quot;Manager&amp;quot;)&lt;br /&gt;
  3  /&lt;br /&gt;
SQL&amp;gt; insert into Employee(ID,  First_Name, Last_Name, Start_Date,                     End_Date,                       Salary,  City,       Description)&lt;br /&gt;
  2                values(&amp;quot;05&amp;quot;,&amp;quot;Robert&amp;quot;,   &amp;quot;Black&amp;quot;,   to_date(&amp;quot;19840115&amp;quot;,&amp;quot;YYYYMMDD&amp;quot;), to_date(&amp;quot;19980808&amp;quot;,&amp;quot;YYYYMMDD&amp;quot;), 2334.78, &amp;quot;Vancouver&amp;quot;,&amp;quot;Tester&amp;quot;)&lt;br /&gt;
  3  /&lt;br /&gt;
SQL&amp;gt; insert into Employee(ID,  First_Name, Last_Name, Start_Date,                     End_Date,                       Salary, City,        Description)&lt;br /&gt;
  2                values(&amp;quot;06&amp;quot;,&amp;quot;Linda&amp;quot;,    &amp;quot;Green&amp;quot;,   to_date(&amp;quot;19870730&amp;quot;,&amp;quot;YYYYMMDD&amp;quot;), to_date(&amp;quot;19960104&amp;quot;,&amp;quot;YYYYMMDD&amp;quot;), 4322.78,&amp;quot;New York&amp;quot;,  &amp;quot;Tester&amp;quot;)&lt;br /&gt;
  3  /&lt;br /&gt;
SQL&amp;gt; insert into Employee(ID,  First_Name, Last_Name, Start_Date,                     End_Date,                       Salary, City,        Description)&lt;br /&gt;
  2                values(&amp;quot;07&amp;quot;,&amp;quot;David&amp;quot;,    &amp;quot;Larry&amp;quot;,   to_date(&amp;quot;19901231&amp;quot;,&amp;quot;YYYYMMDD&amp;quot;), to_date(&amp;quot;19980212&amp;quot;,&amp;quot;YYYYMMDD&amp;quot;), 7897.78,&amp;quot;New York&amp;quot;,  &amp;quot;Manager&amp;quot;)&lt;br /&gt;
  3  /&lt;br /&gt;
SQL&amp;gt; insert into Employee(ID,  First_Name, Last_Name, Start_Date,                     End_Date,                       Salary, City,        Description)&lt;br /&gt;
  2                values(&amp;quot;08&amp;quot;,&amp;quot;James&amp;quot;,    &amp;quot;Cat&amp;quot;,     to_date(&amp;quot;19960917&amp;quot;,&amp;quot;YYYYMMDD&amp;quot;), to_date(&amp;quot;20020415&amp;quot;,&amp;quot;YYYYMMDD&amp;quot;), 1232.78,&amp;quot;Vancouver&amp;quot;, &amp;quot;Tester&amp;quot;)&lt;br /&gt;
  3  /&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt; -- display data in the table&lt;br /&gt;
SQL&amp;gt; select * from Employee&lt;br /&gt;
  2  /&lt;br /&gt;
ID   FIRST_NAME LAST_NAME  START_DAT END_DATE      SALARY CITY       DESCRIPTION&lt;br /&gt;
---- ---------- ---------- --------- --------- ---------- ---------- ---------------&lt;br /&gt;
01   Jason      Martin     25-JUL-96 25-JUL-06    1234.56 Toronto    Programmer&lt;br /&gt;
02   Alison     Mathews    21-MAR-76 21-FEB-86    6661.78 Vancouver  Tester&lt;br /&gt;
03   James      Smith      12-DEC-78 15-MAR-90    6544.78 Vancouver  Tester&lt;br /&gt;
04   Celia      Rice       24-OCT-82 21-APR-99    2344.78 Vancouver  Manager&lt;br /&gt;
05   Robert     Black      15-JAN-84 08-AUG-98    2334.78 Vancouver  Tester&lt;br /&gt;
06   Linda      Green      30-JUL-87 04-JAN-96    4322.78 New York   Tester&lt;br /&gt;
07   David      Larry      31-DEC-90 12-FEB-98    7897.78 New York   Manager&lt;br /&gt;
08   James      Cat        17-SEP-96 15-APR-02    1232.78 Vancouver  Tester&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt; create table employees_copy as select * from employee;&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt; create table employees_log(&lt;br /&gt;
  2    who      varchar2(30),&lt;br /&gt;
  3    action   varchar2(100),&lt;br /&gt;
  4    when     date );&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt; create or replace trigger biud_employees_copy&lt;br /&gt;
  2    before insert or update or delete&lt;br /&gt;
  3       on employees_copy&lt;br /&gt;
  4  begin&lt;br /&gt;
  5    state_package.rows_changed := 0;&lt;br /&gt;
  6  end;&lt;br /&gt;
  7  /&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt; create trigger biudfer_employees_copy&lt;br /&gt;
  2    before insert or update or delete&lt;br /&gt;
  3       on employees_copy&lt;br /&gt;
  4    for each row&lt;br /&gt;
  5  declare&lt;br /&gt;
  6    l_action employees_log.action%type;&lt;br /&gt;
  7  begin&lt;br /&gt;
  8    if INSERTING then&lt;br /&gt;
  9      l_action := &amp;quot;Insert&amp;quot;;&lt;br /&gt;
 10    elsif UPDATING then&lt;br /&gt;
 11      l_action := &amp;quot;Update&amp;quot;;&lt;br /&gt;
 12    elsif DELETING then&lt;br /&gt;
 13      l_action := &amp;quot;Delete&amp;quot;;&lt;br /&gt;
 14    else&lt;br /&gt;
 15      raise_application_error( -20001,&lt;br /&gt;
 16        &amp;quot;You should never ever get this error.&amp;quot; );&lt;br /&gt;
 17    end if;&lt;br /&gt;
 18&lt;br /&gt;
 19    state_package.rows_changed := state_package.rows_changed + 1;&lt;br /&gt;
 20&lt;br /&gt;
 21    if UPDATING( &amp;quot;SALARY&amp;quot; ) then&lt;br /&gt;
 22      l_action := l_action || &amp;quot; - &amp;quot; ||&lt;br /&gt;
 23                  &amp;quot;Salary for id &amp;quot; || :old.id ||&lt;br /&gt;
 24                  &amp;quot; changed from &amp;quot; || :old.salary ||&lt;br /&gt;
 25                  &amp;quot; to &amp;quot; || :new.salary;&lt;br /&gt;
 26    end if;&lt;br /&gt;
 27&lt;br /&gt;
 28    insert into employees_log(&lt;br /&gt;
 29      who, action, when )&lt;br /&gt;
 30      values(&lt;br /&gt;
 31        user, l_action, sysdate );&lt;br /&gt;
 32  end;&lt;br /&gt;
 33  /&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt; create trigger aiud_employees_copy&lt;br /&gt;
  2    after insert or update or delete&lt;br /&gt;
  3     on employees_copy&lt;br /&gt;
  4  declare&lt;br /&gt;
  5    l_action employees_log.action%type;&lt;br /&gt;
  6  begin&lt;br /&gt;
  7    if INSERTING then&lt;br /&gt;
  8      l_action := state_package.rows_changed || &amp;quot; were &amp;quot; || &amp;quot;inserted&amp;quot;;&lt;br /&gt;
  9    elsif UPDATING then&lt;br /&gt;
 10      l_action := state_package.rows_changed || &amp;quot; were &amp;quot; || &amp;quot;updated&amp;quot;;&lt;br /&gt;
 11    elsif DELETING then&lt;br /&gt;
 12      l_action := state_package.rows_changed || &amp;quot; were &amp;quot; || &amp;quot;deleted&amp;quot;;&lt;br /&gt;
 13    else&lt;br /&gt;
 14      raise_application_error( -20001,&lt;br /&gt;
 15        &amp;quot;You should never ever get this error.&amp;quot; );&lt;br /&gt;
 16    end if;&lt;br /&gt;
 17&lt;br /&gt;
 18    insert into employees_log(&lt;br /&gt;
 19      who, action, when )&lt;br /&gt;
 20      values(&lt;br /&gt;
 21        user, l_action, sysdate );&lt;br /&gt;
 22  end;&lt;br /&gt;
 23  /&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt; update employees_copy set salary = salary * 0.95;&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt; select * from employees_log;&lt;br /&gt;
WHO                            ACTION                                                                                       WHEN&lt;br /&gt;
------------------------------ ---------------------------------------------------------------------------------------------------- ---------&lt;br /&gt;
sqle                         Update - Salary for id 01 changed from 1234.56 to 1172.83                                    09-SEP-06&lt;br /&gt;
sqle                         Update - Salary for id 02 changed from 6661.78 to 6328.69                                    09-SEP-06&lt;br /&gt;
sqle                         Update - Salary for id 03 changed from 6544.78 to 6217.54                                    09-SEP-06&lt;br /&gt;
sqle                         Update - Salary for id 04 changed from 2344.78 to 2227.54                                    09-SEP-06&lt;br /&gt;
sqle                         Update - Salary for id 05 changed from 2334.78 to 2218.04                                    09-SEP-06&lt;br /&gt;
sqle                         Update - Salary for id 06 changed from 4322.78 to 4106.64                                    09-SEP-06&lt;br /&gt;
sqle                         Update - Salary for id 07 changed from 7897.78 to 7502.89                                    09-SEP-06&lt;br /&gt;
sqle                         Update - Salary for id 08 changed from 1232.78 to 1171.14                                    09-SEP-06&lt;br /&gt;
sqle                         8 were updated                                                                               09-SEP-06&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt; drop table employees_copy;&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt; drop table employees_log;&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt; -- clean the table&lt;br /&gt;
SQL&amp;gt; drop table Employee&lt;br /&gt;
  2  /&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
SQL&amp;gt;&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>