<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.sqle.ru/index.php?action=history&amp;feed=atom&amp;title=SQL_Server%2FT-SQL_Tutorial%2FTrigger%2FUtility_trigger</id>
		<title>SQL Server/T-SQL Tutorial/Trigger/Utility trigger - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.sqle.ru/index.php?action=history&amp;feed=atom&amp;title=SQL_Server%2FT-SQL_Tutorial%2FTrigger%2FUtility_trigger"/>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Trigger/Utility_trigger&amp;action=history"/>
		<updated>2026-05-24T22:36:44Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Trigger/Utility_trigger&amp;diff=6821&amp;oldid=prev</id>
		<title> в 13:46, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Trigger/Utility_trigger&amp;diff=6821&amp;oldid=prev"/>
				<updated>2010-05-26T13:46:16Z</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:46, 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://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Trigger/Utility_trigger&amp;diff=6822&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Trigger/Utility_trigger&amp;diff=6822&amp;oldid=prev"/>
				<updated>2010-05-26T10:24:31Z</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;== A CREATE TRIGGER statement that corrects mixed-case state names==&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;
8&amp;gt; create table Bankers(&lt;br /&gt;
9&amp;gt;    BankerID             Integer,&lt;br /&gt;
10&amp;gt;    BankerName           VARCHAR(20),&lt;br /&gt;
11&amp;gt;    BankerContactLName   VARCHAR(20),&lt;br /&gt;
12&amp;gt;    BankerContactFName   VARCHAR(20),&lt;br /&gt;
13&amp;gt;    BankerCity           VARCHAR(20),&lt;br /&gt;
14&amp;gt;    BankerState          VARCHAR(20),&lt;br /&gt;
15&amp;gt;    BankerZipCode        VARCHAR(20),&lt;br /&gt;
16&amp;gt;    BankerPhone          VARCHAR(20)&lt;br /&gt;
17&amp;gt; )&lt;br /&gt;
18&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; insert into Bankers values (1, &amp;quot;ABC Inc.&amp;quot;,&amp;quot;Joe&amp;quot;,&amp;quot;Smith&amp;quot;,&amp;quot;Vancouver&amp;quot;,&amp;quot;BC&amp;quot;,&amp;quot;11111&amp;quot;,&amp;quot;111-111-1111&amp;quot;);&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (2, &amp;quot;DEF Inc.&amp;quot;,&amp;quot;Red&amp;quot;,&amp;quot;Rice&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;DE&amp;quot;,&amp;quot;22222&amp;quot;,&amp;quot;222-222-2222&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (3, &amp;quot;HJI Inc.&amp;quot;,&amp;quot;Kit&amp;quot;,&amp;quot;Cat&amp;quot;,  &amp;quot;Paris&amp;quot;,    &amp;quot;CA&amp;quot;,&amp;quot;33333&amp;quot;,&amp;quot;333-333-3333&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (4, &amp;quot;QWE Inc.&amp;quot;,&amp;quot;Git&amp;quot;,&amp;quot;Black&amp;quot;,&amp;quot;Regina&amp;quot;,   &amp;quot;ER&amp;quot;,&amp;quot;44444&amp;quot;,&amp;quot;444-444-4444&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (5, &amp;quot;RTY Inc.&amp;quot;,&amp;quot;Wil&amp;quot;,&amp;quot;Lee&amp;quot;,  &amp;quot;Toronto&amp;quot;,  &amp;quot;YU&amp;quot;,&amp;quot;55555&amp;quot;,&amp;quot;555-555-5555&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (6, &amp;quot;YUI Inc.&amp;quot;,&amp;quot;Ted&amp;quot;,&amp;quot;Larry&amp;quot;,&amp;quot;Calgary&amp;quot;,  &amp;quot;TY&amp;quot;,&amp;quot;66666&amp;quot;,&amp;quot;666-666-6666&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (7, &amp;quot;OIP Inc.&amp;quot;,&amp;quot;Yam&amp;quot;,&amp;quot;Act&amp;quot;,  &amp;quot;San Franc&amp;quot;,&amp;quot;FG&amp;quot;,&amp;quot;77777&amp;quot;,&amp;quot;777-777-7777&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (8, &amp;quot;SAD Inc.&amp;quot;,&amp;quot;Hit&amp;quot;,&amp;quot;Eat&amp;quot;,  &amp;quot;Orland&amp;quot;,   &amp;quot;PO&amp;quot;,&amp;quot;88888&amp;quot;,&amp;quot;888-888-8888&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (9, &amp;quot;DFG Inc.&amp;quot;,&amp;quot;Sad&amp;quot;,&amp;quot;Lee&amp;quot;,  &amp;quot;Wisler&amp;quot;,   &amp;quot;PL&amp;quot;,&amp;quot;99999&amp;quot;,&amp;quot;999-999-9999&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (0, &amp;quot;GHJ Inc.&amp;quot;,&amp;quot;Bit&amp;quot;,&amp;quot;Lee&amp;quot;,  &amp;quot;Ticker&amp;quot;,   &amp;quot;MN&amp;quot;,&amp;quot;00000&amp;quot;,&amp;quot;000-000-0000&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; CREATE TRIGGER Bankers_INSERT_UPDATE&lt;br /&gt;
3&amp;gt;     ON Bankers&lt;br /&gt;
4&amp;gt;     AFTER INSERT,UPDATE&lt;br /&gt;
5&amp;gt; AS&lt;br /&gt;
6&amp;gt;     UPDATE Bankers&lt;br /&gt;
7&amp;gt;     SET BankerState = UPPER(BankerState)&lt;br /&gt;
8&amp;gt;     WHERE BankerID IN (SELECT BankerID FROM Inserted)&lt;br /&gt;
9&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; insert into Bankers values (0, &amp;quot;GHJ Inc.&amp;quot;,&amp;quot;Bit&amp;quot;,&amp;quot;Lee&amp;quot;,  &amp;quot;Ticker&amp;quot;,   &amp;quot;MN&amp;quot;,&amp;quot;00000&amp;quot;,&amp;quot;000-000-0000&amp;quot;);&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; drop trigger Bankers_INSERT_UPDATE;&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table Bankers;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== A script that creates AFTER triggers to maintain referential integrity==&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;
4&amp;gt;&lt;br /&gt;
5&amp;gt; create table Billings (&lt;br /&gt;
6&amp;gt;     BankerID           INTEGER,&lt;br /&gt;
7&amp;gt;     BillingNumber      INTEGER,&lt;br /&gt;
8&amp;gt;     BillingDate        datetime,&lt;br /&gt;
9&amp;gt;     BillingTotal       INTEGER,&lt;br /&gt;
10&amp;gt;     TermsID            INTEGER,&lt;br /&gt;
11&amp;gt;     BillingDueDate     datetime ,&lt;br /&gt;
12&amp;gt;     PaymentTotal       INTEGER,&lt;br /&gt;
13&amp;gt;     CreditTotal        INTEGER&lt;br /&gt;
14&amp;gt;&lt;br /&gt;
15&amp;gt; );&lt;br /&gt;
16&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; INSERT INTO Billings VALUES (1, 1, &amp;quot;2005-01-22&amp;quot;, 165, 1,&amp;quot;2005-04-22&amp;quot;,123,321);&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (2, 2, &amp;quot;2001-02-21&amp;quot;, 165, 1,&amp;quot;2002-02-22&amp;quot;,123,321.);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (3, 3, &amp;quot;2003-05-02&amp;quot;, 165, 1,&amp;quot;2005-04-12&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (4, 4, &amp;quot;1999-03-12&amp;quot;, 165, 1,&amp;quot;2005-04-18&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (5, 5, &amp;quot;2000-04-23&amp;quot;, 165, 1,&amp;quot;2005-04-17&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (6, 6, &amp;quot;2001-06-14&amp;quot;, 165, 1,&amp;quot;2005-04-18&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (7, 7, &amp;quot;2002-07-15&amp;quot;, 165, 1,&amp;quot;2005-04-19&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (8, 8, &amp;quot;2003-08-16&amp;quot;, 165, 1,&amp;quot;2005-04-20&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (9, 9, &amp;quot;2004-09-17&amp;quot;, 165, 1,&amp;quot;2005-04-21&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (0, 0, &amp;quot;2005-10-18&amp;quot;, 165, 1,&amp;quot;2005-04-22&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; create table Bankers(&lt;br /&gt;
4&amp;gt;    BankerID             Integer,&lt;br /&gt;
5&amp;gt;    BankerName           VARCHAR(20),&lt;br /&gt;
6&amp;gt;    BankerContactLName   VARCHAR(20),&lt;br /&gt;
7&amp;gt;    BankerContactFName   VARCHAR(20),&lt;br /&gt;
8&amp;gt;    BankerCity           VARCHAR(20),&lt;br /&gt;
9&amp;gt;    BankerState          VARCHAR(20),&lt;br /&gt;
10&amp;gt;    BankerZipCode        VARCHAR(20),&lt;br /&gt;
11&amp;gt;    BankerPhone          VARCHAR(20)&lt;br /&gt;
12&amp;gt; )&lt;br /&gt;
13&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; insert into Bankers values (1, &amp;quot;ABC Inc.&amp;quot;,&amp;quot;Joe&amp;quot;,&amp;quot;Smith&amp;quot;,&amp;quot;Vancouver&amp;quot;,&amp;quot;BC&amp;quot;,&amp;quot;11111&amp;quot;,&amp;quot;111-111-1111&amp;quot;);&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (2, &amp;quot;DEF Inc.&amp;quot;,&amp;quot;Red&amp;quot;,&amp;quot;Rice&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;DE&amp;quot;,&amp;quot;22222&amp;quot;,&amp;quot;222-222-2222&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (3, &amp;quot;HJI Inc.&amp;quot;,&amp;quot;Kit&amp;quot;,&amp;quot;Cat&amp;quot;,  &amp;quot;Paris&amp;quot;,    &amp;quot;CA&amp;quot;,&amp;quot;33333&amp;quot;,&amp;quot;333-333-3333&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (4, &amp;quot;QWE Inc.&amp;quot;,&amp;quot;Git&amp;quot;,&amp;quot;Black&amp;quot;,&amp;quot;Regina&amp;quot;,   &amp;quot;ER&amp;quot;,&amp;quot;44444&amp;quot;,&amp;quot;444-444-4444&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (5, &amp;quot;RTY Inc.&amp;quot;,&amp;quot;Wil&amp;quot;,&amp;quot;Lee&amp;quot;,  &amp;quot;Toronto&amp;quot;,  &amp;quot;YU&amp;quot;,&amp;quot;55555&amp;quot;,&amp;quot;555-555-5555&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (6, &amp;quot;YUI Inc.&amp;quot;,&amp;quot;Ted&amp;quot;,&amp;quot;Larry&amp;quot;,&amp;quot;Calgary&amp;quot;,  &amp;quot;TY&amp;quot;,&amp;quot;66666&amp;quot;,&amp;quot;666-666-6666&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (7, &amp;quot;OIP Inc.&amp;quot;,&amp;quot;Yam&amp;quot;,&amp;quot;Act&amp;quot;,  &amp;quot;San Franc&amp;quot;,&amp;quot;FG&amp;quot;,&amp;quot;77777&amp;quot;,&amp;quot;777-777-7777&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (8, &amp;quot;SAD Inc.&amp;quot;,&amp;quot;Hit&amp;quot;,&amp;quot;Eat&amp;quot;,  &amp;quot;Orland&amp;quot;,   &amp;quot;PO&amp;quot;,&amp;quot;88888&amp;quot;,&amp;quot;888-888-8888&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (9, &amp;quot;DFG Inc.&amp;quot;,&amp;quot;Sad&amp;quot;,&amp;quot;Lee&amp;quot;,  &amp;quot;Wisler&amp;quot;,   &amp;quot;PL&amp;quot;,&amp;quot;99999&amp;quot;,&amp;quot;999-999-9999&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (0, &amp;quot;GHJ Inc.&amp;quot;,&amp;quot;Bit&amp;quot;,&amp;quot;Lee&amp;quot;,  &amp;quot;Ticker&amp;quot;,   &amp;quot;MN&amp;quot;,&amp;quot;00000&amp;quot;,&amp;quot;000-000-0000&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; CREATE TRIGGER Banker_UPDATE_DELETE_RI&lt;br /&gt;
4&amp;gt;     ON Bankers&lt;br /&gt;
5&amp;gt;     AFTER DELETE,UPDATE&lt;br /&gt;
6&amp;gt; AS&lt;br /&gt;
7&amp;gt;     IF EXISTS (SELECT * FROM Deleted JOIN Billings&lt;br /&gt;
8&amp;gt;                         ON Deleted.BankerID = Billings.BankerID)&lt;br /&gt;
9&amp;gt;     BEGIN&lt;br /&gt;
10&amp;gt;         RAISERROR(&amp;quot;BankerID in use.&amp;quot;,1,1)&lt;br /&gt;
11&amp;gt;         ROLLBACK TRAN&lt;br /&gt;
12&amp;gt;     END&lt;br /&gt;
13&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; CREATE TRIGGER Billing_INSERT_UPDATE_RI&lt;br /&gt;
3&amp;gt;     ON Billings&lt;br /&gt;
4&amp;gt;     AFTER INSERT,UPDATE&lt;br /&gt;
5&amp;gt; AS&lt;br /&gt;
6&amp;gt;     IF NOT EXISTS (SELECT * FROM Bankers&lt;br /&gt;
7&amp;gt;                    WHERE BankerID IN (SELECT BankerID FROM Inserted))&lt;br /&gt;
8&amp;gt;     BEGIN&lt;br /&gt;
9&amp;gt;         RAISERROR(&amp;quot;Invalid BankerID.&amp;quot;,1,1)&lt;br /&gt;
10&amp;gt;         ROLLBACK TRAN&lt;br /&gt;
11&amp;gt;     END&lt;br /&gt;
12&amp;gt; GO&lt;br /&gt;
1&amp;gt; &lt;br /&gt;
2&amp;gt; DELETE Bankers&lt;br /&gt;
3&amp;gt; WHERE BankerID = 34&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(0 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop TRIGGER Banker_UPDATE_DELETE_RI;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table Bankers;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; drop table Billings;&lt;br /&gt;
4&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Auditing Triggers==&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;
4&amp;gt;&lt;br /&gt;
5&amp;gt;&lt;br /&gt;
6&amp;gt; CREATE TABLE sales(&lt;br /&gt;
7&amp;gt;    stor_id        char(4)           NOT NULL,&lt;br /&gt;
8&amp;gt;    ord_num        varchar(20)       NOT NULL,&lt;br /&gt;
9&amp;gt;    ord_date       datetime          NOT NULL,&lt;br /&gt;
10&amp;gt;    qty            smallint          NOT NULL,&lt;br /&gt;
11&amp;gt;    payterms       varchar(12)       NOT NULL,&lt;br /&gt;
12&amp;gt;    title_id       varchar(80)&lt;br /&gt;
13&amp;gt; )&lt;br /&gt;
14&amp;gt; GO&lt;br /&gt;
1&amp;gt; insert sales values(&amp;quot;1&amp;quot;, &amp;quot;QA7442.3&amp;quot;, &amp;quot;09/13/94&amp;quot;, 75, &amp;quot;ON Billing&amp;quot;,&amp;quot;1&amp;quot;)&lt;br /&gt;
2&amp;gt; insert sales values(&amp;quot;2&amp;quot;, &amp;quot;D4482&amp;quot;,    &amp;quot;09/14/94&amp;quot;, 10, &amp;quot;Net 60&amp;quot;,    &amp;quot;1&amp;quot;)&lt;br /&gt;
3&amp;gt; insert sales values(&amp;quot;3&amp;quot;, &amp;quot;N914008&amp;quot;,  &amp;quot;09/14/94&amp;quot;, 20, &amp;quot;Net 30&amp;quot;,    &amp;quot;2&amp;quot;)&lt;br /&gt;
4&amp;gt; insert sales values(&amp;quot;4&amp;quot;, &amp;quot;N914014&amp;quot;,  &amp;quot;09/14/94&amp;quot;, 25, &amp;quot;Net 30&amp;quot;,    &amp;quot;3&amp;quot;)&lt;br /&gt;
5&amp;gt; insert sales values(&amp;quot;5&amp;quot;, &amp;quot;423LL922&amp;quot;, &amp;quot;09/14/94&amp;quot;, 15, &amp;quot;ON Billing&amp;quot;,&amp;quot;3&amp;quot;)&lt;br /&gt;
6&amp;gt; insert sales values(&amp;quot;6&amp;quot;, &amp;quot;423LL930&amp;quot;, &amp;quot;09/14/94&amp;quot;, 10, &amp;quot;ON Billing&amp;quot;,&amp;quot;2&amp;quot;)&lt;br /&gt;
7&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;     CREATE TABLE SalesArchive (&lt;br /&gt;
2&amp;gt;        stor_id        CHAR(4)           NOT NULL,&lt;br /&gt;
3&amp;gt;        ord_num        VARCHAR(20)       NOT NULL,&lt;br /&gt;
4&amp;gt;        ord_date       DATETIME          NOT NULL,&lt;br /&gt;
5&amp;gt;        qty            SMALLINT          NOT NULL,&lt;br /&gt;
6&amp;gt;        payterms       VARCHAR(12)       NOT NULL,&lt;br /&gt;
7&amp;gt;        title_id       CHAR(4),&lt;br /&gt;
8&amp;gt;     )&lt;br /&gt;
9&amp;gt;     GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; &lt;br /&gt;
3&amp;gt;     CREATE TRIGGER trSales_Del ON sales&lt;br /&gt;
4&amp;gt;     FOR DELETE&lt;br /&gt;
5&amp;gt;     AS&lt;br /&gt;
6&amp;gt;     INSERT SalesArchive&lt;br /&gt;
7&amp;gt;         SELECT stor_id, ord_num, ord_date, qty, payterms, title_id&lt;br /&gt;
8&amp;gt;             FROM deleted&lt;br /&gt;
9&amp;gt;     GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;    drop trigger trSales_Del;&lt;br /&gt;
4&amp;gt;    GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;    drop table SalesArchive;&lt;br /&gt;
3&amp;gt;    GO&lt;br /&gt;
1&amp;gt;    drop table sales;&lt;br /&gt;
2&amp;gt;    GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Creating the UpdateLog table and an update trigger on the authors 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;
4&amp;gt;&lt;br /&gt;
5&amp;gt;&lt;br /&gt;
6&amp;gt; CREATE TABLE authors(&lt;br /&gt;
7&amp;gt;    au_id          varchar(11),&lt;br /&gt;
8&amp;gt;    au_lname       varchar(40)       NOT NULL,&lt;br /&gt;
9&amp;gt;    au_fname       varchar(20)       NOT NULL,&lt;br /&gt;
10&amp;gt;    phone          char(12)          NOT NULL DEFAULT (&amp;quot;UNKNOWN&amp;quot;),&lt;br /&gt;
11&amp;gt;    address        varchar(40)           NULL,&lt;br /&gt;
12&amp;gt;    city           varchar(20)           NULL,&lt;br /&gt;
13&amp;gt;    state          char(2)               NULL,&lt;br /&gt;
14&amp;gt;    zip            char(5)               NULL,&lt;br /&gt;
15&amp;gt;    contract       bit               NOT NULL&lt;br /&gt;
16&amp;gt; )&lt;br /&gt;
17&amp;gt; GO&lt;br /&gt;
1&amp;gt; insert authors values(&amp;quot;1&amp;quot;,  &amp;quot;Joe&amp;quot;,   &amp;quot;Abra&amp;quot;,   &amp;quot;111 111-1111&amp;quot;, &amp;quot;6 St.&amp;quot;, &amp;quot;Berkeley&amp;quot;,  &amp;quot;CA&amp;quot;, &amp;quot;11111&amp;quot;, 1)&lt;br /&gt;
2&amp;gt; insert authors values(&amp;quot;2&amp;quot;,  &amp;quot;Jack&amp;quot;,  &amp;quot;Majo&amp;quot;,   &amp;quot;222 222-2222&amp;quot;, &amp;quot;3 St.&amp;quot;, &amp;quot;Oakland&amp;quot; ,  &amp;quot;CA&amp;quot;, &amp;quot;22222&amp;quot;, 1)&lt;br /&gt;
3&amp;gt; insert authors values(&amp;quot;3&amp;quot;,  &amp;quot;Pink&amp;quot;,  &amp;quot;Cherry&amp;quot;, &amp;quot;333 333-3333&amp;quot;, &amp;quot;5 Ln.&amp;quot;, &amp;quot;Vancouver&amp;quot;, &amp;quot;BC&amp;quot;, &amp;quot;33333&amp;quot;, 1)&lt;br /&gt;
4&amp;gt; insert authors values(&amp;quot;4&amp;quot;,  &amp;quot;Blue&amp;quot;,  &amp;quot;Albert&amp;quot;, &amp;quot;444 444-4444&amp;quot;, &amp;quot;7 Av.&amp;quot;, &amp;quot;Vancouver&amp;quot;, &amp;quot;BC&amp;quot;, &amp;quot;44444&amp;quot;, 1)&lt;br /&gt;
5&amp;gt; insert authors values(&amp;quot;5&amp;quot;,  &amp;quot;Red&amp;quot;,   &amp;quot;Anne&amp;quot;,   &amp;quot;555 555-5555&amp;quot;, &amp;quot;6 Av.&amp;quot;, &amp;quot;Regina&amp;quot;,    &amp;quot;SK&amp;quot;, &amp;quot;55555&amp;quot;, 1)&lt;br /&gt;
6&amp;gt; insert authors values(&amp;quot;6&amp;quot;,  &amp;quot;Black&amp;quot;, &amp;quot;Michel&amp;quot;, &amp;quot;666 666-6666&amp;quot;, &amp;quot;3 Pl.&amp;quot;, &amp;quot;Regina&amp;quot;,    &amp;quot;SK&amp;quot;, &amp;quot;66666&amp;quot;, 1)&lt;br /&gt;
7&amp;gt; insert authors values(&amp;quot;7&amp;quot;,  &amp;quot;White&amp;quot;, &amp;quot;Sylvia&amp;quot;, &amp;quot;777 777-7777&amp;quot;, &amp;quot;1 Pl.&amp;quot;, &amp;quot;Rockville&amp;quot;, &amp;quot;MD&amp;quot;, &amp;quot;77777&amp;quot;, 1)&lt;br /&gt;
8&amp;gt; insert authors values(&amp;quot;8&amp;quot;,  &amp;quot;Yellow&amp;quot;,&amp;quot;Heather&amp;quot;,&amp;quot;888 888-8888&amp;quot;, &amp;quot;3 Pu&amp;quot;,  &amp;quot;Vacaville&amp;quot;, &amp;quot;CA&amp;quot;, &amp;quot;88888&amp;quot;, 0)&lt;br /&gt;
9&amp;gt; insert authors values(&amp;quot;9&amp;quot;,  &amp;quot;Gold&amp;quot;,  &amp;quot;Dep&amp;quot;,    &amp;quot;999 999-9999&amp;quot;, &amp;quot;5 Av.&amp;quot;, &amp;quot;Oakland&amp;quot;,   &amp;quot;CA&amp;quot;, &amp;quot;99999&amp;quot;, 0)&lt;br /&gt;
10&amp;gt; insert authors values(&amp;quot;10&amp;quot;, &amp;quot;Siler&amp;quot;, &amp;quot;Dean&amp;quot;,   &amp;quot;000 000-0000&amp;quot;, &amp;quot;4 Av.&amp;quot;, &amp;quot;Oakland&amp;quot;,   &amp;quot;CA&amp;quot;, &amp;quot;00000&amp;quot;, 1)&lt;br /&gt;
11&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;     CREATE TABLE UpdateLog&lt;br /&gt;
3&amp;gt;     (&lt;br /&gt;
4&amp;gt;         table_name VARCHAR(30) NOT NULL,&lt;br /&gt;
5&amp;gt;         column_name VARCHAR(30) NOT NULL,&lt;br /&gt;
6&amp;gt;         updated_by VARCHAR(30) NOT NULL,&lt;br /&gt;
7&amp;gt;         updated_when DATETIME NOT NULL&lt;br /&gt;
8&amp;gt;     )&lt;br /&gt;
9&amp;gt;     GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;     CREATE TRIGGER trAuthors_Upd ON Authors&lt;br /&gt;
3&amp;gt;     FOR UPDATE&lt;br /&gt;
4&amp;gt;     AS&lt;br /&gt;
5&amp;gt;     DECLARE @intRowCount int&lt;br /&gt;
6&amp;gt;     SELECT @intRowCount = @@RowCount&lt;br /&gt;
7&amp;gt;     IF @intRowCount &amp;gt; 0&lt;br /&gt;
8&amp;gt;         BEGIN&lt;br /&gt;
9&amp;gt;             IF UPDATE(au_id)&lt;br /&gt;
10&amp;gt;                 INSERT UpdateLog VALUES (&amp;quot;authors&amp;quot;, &amp;quot;au_id&amp;quot;, suser_name(), getdate())&lt;br /&gt;
11&amp;gt;             IF UPDATE(au_lname)&lt;br /&gt;
12&amp;gt;                 INSERT UpdateLog VALUES (&amp;quot;authors&amp;quot;, &amp;quot;au_lname&amp;quot;, suser_name(), getdate())&lt;br /&gt;
13&amp;gt;             IF UPDATE(au_fname)&lt;br /&gt;
14&amp;gt;                 INSERT UpdateLog VALUES (&amp;quot;authors&amp;quot;, &amp;quot;au_fname&amp;quot;, suser_name(), getdate())&lt;br /&gt;
15&amp;gt;             IF UPDATE(phone)&lt;br /&gt;
16&amp;gt;                 INSERT UpdateLog VALUES (&amp;quot;authors&amp;quot;, &amp;quot;phone&amp;quot;, suser_name(), getdate())&lt;br /&gt;
17&amp;gt;             IF UPDATE(address)&lt;br /&gt;
18&amp;gt;                 INSERT UpdateLog VALUES (&amp;quot;authors&amp;quot;, &amp;quot;address&amp;quot;, suser_name(), getdate())&lt;br /&gt;
19&amp;gt;             IF UPDATE(city)&lt;br /&gt;
20&amp;gt;                 INSERT UpdateLog VALUES (&amp;quot;authors&amp;quot;, &amp;quot;city&amp;quot;, suser_name(), getdate())&lt;br /&gt;
21&amp;gt;             IF UPDATE(state)&lt;br /&gt;
22&amp;gt;                 INSERT UpdateLog VALUES (&amp;quot;authors&amp;quot;, &amp;quot;state&amp;quot;, suser_name(), getdate())&lt;br /&gt;
23&amp;gt;             IF UPDATE(zip)&lt;br /&gt;
24&amp;gt;                 INSERT UpdateLog VALUES (&amp;quot;authors&amp;quot;, &amp;quot;zip&amp;quot;, suser_name(), getdate())&lt;br /&gt;
25&amp;gt;             IF UPDATE(contract)&lt;br /&gt;
26&amp;gt;                 INSERT UpdateLog VALUES (&amp;quot;authors&amp;quot;, &amp;quot;contract&amp;quot;, suser_name(), getdate())&lt;br /&gt;
27&amp;gt;         END&lt;br /&gt;
28&amp;gt;     GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;     drop trigger trAuthors_Upd;&lt;br /&gt;
4&amp;gt;     GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;     drop table sales;&lt;br /&gt;
3&amp;gt;     drop table UpdateLog;&lt;br /&gt;
4&amp;gt;     GO&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>