<?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%2FInserted_table</id>
		<title>SQL Server/T-SQL Tutorial/Trigger/Inserted table - История изменений</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%2FInserted_table"/>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Trigger/Inserted_table&amp;action=history"/>
		<updated>2026-06-10T15:28:46Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Trigger/Inserted_table&amp;diff=6831&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/Inserted_table&amp;diff=6831&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/Inserted_table&amp;diff=6832&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/Inserted_table&amp;diff=6832&amp;oldid=prev"/>
				<updated>2010-05-26T10:24:34Z</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;== COUNT(*) FROM Inserted==&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;
2&amp;gt; CREATE TABLE Orders (&lt;br /&gt;
3&amp;gt;      OrderID int IDENTITY (1, 1) NOT NULL ,&lt;br /&gt;
4&amp;gt;      CustomerID nchar (5) NULL ,&lt;br /&gt;
5&amp;gt;      EmployeeID int NULL ,&lt;br /&gt;
6&amp;gt;      OrderDate datetime NULL ,&lt;br /&gt;
7&amp;gt;      RequiredDate datetime NULL ,&lt;br /&gt;
8&amp;gt;      ShippedDate datetime NULL ,&lt;br /&gt;
9&amp;gt;      ShipVia int NULL ,&lt;br /&gt;
10&amp;gt;     Freight money NULL DEFAULT (0),&lt;br /&gt;
11&amp;gt;     ShipName nvarchar (40) NULL ,&lt;br /&gt;
12&amp;gt;     ShipAddress nvarchar (60) NULL ,&lt;br /&gt;
13&amp;gt;     ShipCity nvarchar (15) NULL ,&lt;br /&gt;
14&amp;gt;     ShipRegion nvarchar (15) NULL ,&lt;br /&gt;
15&amp;gt;     ShipPostalCode nvarchar (10) NULL ,&lt;br /&gt;
16&amp;gt;     ShipCountry nvarchar (15) NULL&lt;br /&gt;
17&amp;gt; )&lt;br /&gt;
18&amp;gt; GO&lt;br /&gt;
1&amp;gt;    CREATE TRIGGER OrdersFeedsOrders&lt;br /&gt;
2&amp;gt;       ON Orders&lt;br /&gt;
3&amp;gt;       FOR INSERT, UPDATE, DELETE&lt;br /&gt;
4&amp;gt;    AS&lt;br /&gt;
5&amp;gt;       DECLARE @Count int&lt;br /&gt;
6&amp;gt;       SELECT @Count = COUNT(*) FROM DELETED&lt;br /&gt;
7&amp;gt;       IF @Count &amp;gt; 0&lt;br /&gt;
8&amp;gt;       BEGIN&lt;br /&gt;
9&amp;gt;          DELETE FROM Orders&lt;br /&gt;
10&amp;gt;             FROM DELETED i&lt;br /&gt;
11&amp;gt;             JOIN Orders o2&lt;br /&gt;
12&amp;gt;                ON i.OrderID = o2.OrderID&lt;br /&gt;
13&amp;gt;       END&lt;br /&gt;
14&amp;gt;       IF @@ERROR != 0&lt;br /&gt;
15&amp;gt;          ROLLBACK TRAN&lt;br /&gt;
16&amp;gt;&lt;br /&gt;
17&amp;gt;       SELECT @Count = COUNT(*) FROM Inserted&lt;br /&gt;
18&amp;gt;&lt;br /&gt;
19&amp;gt;       IF @Count &amp;gt; 0&lt;br /&gt;
20&amp;gt;       BEGIN&lt;br /&gt;
21&amp;gt;          INSERT INTO Orders&lt;br /&gt;
22&amp;gt;             SELECT i.*&lt;br /&gt;
23&amp;gt;             FROM Inserted i&lt;br /&gt;
24&amp;gt;             LEFT JOIN Orders o2&lt;br /&gt;
25&amp;gt;                ON i.OrderID = o2.OrderID&lt;br /&gt;
26&amp;gt;             WHERE o2.OrderID IS NULL&lt;br /&gt;
27&amp;gt;       END&lt;br /&gt;
28&amp;gt;&lt;br /&gt;
29&amp;gt;       IF @@ERROR != 0&lt;br /&gt;
30&amp;gt;          ROLLBACK TRAN&lt;br /&gt;
31&amp;gt;       GO&lt;br /&gt;
Msg 8101, Level 16, State 1, Server J\SQLEXPRESS, Procedure OrdersFeedsOrders, Line 21&lt;br /&gt;
An explicit value for the identity column in table &amp;quot;Orders&amp;quot; can only be specified when a column list is used and IDENTITY_INSERT is ON.&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
1&amp;gt;       drop table Orders;&lt;br /&gt;
2&amp;gt;       GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Count Inserted 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;
2&amp;gt;&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt;&lt;br /&gt;
5&amp;gt; CREATE TABLE Customers (&lt;br /&gt;
6&amp;gt;      CustomerID nchar (5) NOT NULL ,&lt;br /&gt;
7&amp;gt;      CompanyName nvarchar (40) NOT NULL ,&lt;br /&gt;
8&amp;gt;      ContactName nvarchar (30) NULL ,&lt;br /&gt;
9&amp;gt;      ContactTitle nvarchar (30) NULL ,&lt;br /&gt;
10&amp;gt;     Address nvarchar (60) NULL ,&lt;br /&gt;
11&amp;gt;     City nvarchar (15) NULL ,&lt;br /&gt;
12&amp;gt;     Region nvarchar (15) NULL ,&lt;br /&gt;
13&amp;gt;     PostalCode nvarchar (10) NULL ,&lt;br /&gt;
14&amp;gt;     Country nvarchar (15) NULL ,&lt;br /&gt;
15&amp;gt;     Phone nvarchar (24) NULL ,&lt;br /&gt;
16&amp;gt;     Fax nvarchar (24) NULL&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 Customers VALUES(&amp;quot;1&amp;quot;,&amp;quot;A&amp;quot;,&amp;quot;Maria&amp;quot;,    &amp;quot;Sales&amp;quot;,  &amp;quot;Str. 57&amp;quot;, &amp;quot;Berlin&amp;quot;    ,NULL,&amp;quot;12209&amp;quot;, &amp;quot;Germany&amp;quot;,&amp;quot;111-1111111&amp;quot;,&amp;quot;111-1111111&amp;quot;)&lt;br /&gt;
3&amp;gt; INSERT Customers VALUES(&amp;quot;2&amp;quot;,&amp;quot;M&amp;quot;,&amp;quot;Joe&amp;quot;,      &amp;quot;Owner&amp;quot;,  &amp;quot;Ave. 231&amp;quot;,&amp;quot;Vancouver&amp;quot; ,NULL,&amp;quot;05023&amp;quot;, &amp;quot;Mexico&amp;quot;, &amp;quot;(222) 222-3332&amp;quot;,NULL)&lt;br /&gt;
4&amp;gt; INSERT Customers VALUES(&amp;quot;3&amp;quot;,&amp;quot;H&amp;quot;,&amp;quot;Thomas&amp;quot;,   &amp;quot;Sales&amp;quot;,  &amp;quot;Sq.  111&amp;quot;,&amp;quot;London&amp;quot;    ,NULL,&amp;quot;1D00P&amp;quot;, &amp;quot;UK&amp;quot;,     &amp;quot;(444) 444-4444&amp;quot;,&amp;quot;(444) 444-4444&amp;quot;)&lt;br /&gt;
5&amp;gt; INSERT Customers VALUES(&amp;quot;4&amp;quot;,&amp;quot;B&amp;quot;,&amp;quot;Berg&amp;quot;,     &amp;quot;Order&amp;quot;,  &amp;quot;Blv    8&amp;quot;,&amp;quot;Toronto&amp;quot;   ,NULL,&amp;quot;00222&amp;quot;, &amp;quot;Sweden&amp;quot;, &amp;quot;4444-55 55 65&amp;quot;,&amp;quot;5555-55 55 55&amp;quot;)&lt;br /&gt;
6&amp;gt; INSERT Customers VALUES(&amp;quot;5&amp;quot;,&amp;quot;S&amp;quot;,&amp;quot;Moos&amp;quot;,     &amp;quot;Sales&amp;quot;,  &amp;quot;Fort  57&amp;quot;,&amp;quot;New York&amp;quot;  ,NULL,&amp;quot;68306&amp;quot;, &amp;quot;Germany&amp;quot;,&amp;quot;6666-66666&amp;quot;,&amp;quot;6666-77777&amp;quot;)&lt;br /&gt;
7&amp;gt; INSERT Customers VALUES(&amp;quot;6&amp;quot;,&amp;quot;F&amp;quot;,&amp;quot;Cite&amp;quot;,     &amp;quot;Manager&amp;quot;,&amp;quot;24      &amp;quot;,&amp;quot;Dalles&amp;quot;    ,NULL,&amp;quot;67000&amp;quot;, &amp;quot;France&amp;quot;, &amp;quot;88.60.15.31&amp;quot;,&amp;quot;88.60.15.32&amp;quot;)&lt;br /&gt;
8&amp;gt; INSERT Customers VALUES(&amp;quot;7&amp;quot;,&amp;quot;C&amp;quot;,&amp;quot;Sommer&amp;quot;,   &amp;quot;Owner&amp;quot;,  &amp;quot;Araq, 67&amp;quot;,&amp;quot;Paris&amp;quot;     ,NULL,&amp;quot;28023&amp;quot;, &amp;quot;Spain&amp;quot;,  &amp;quot;(91) 555 22 82&amp;quot;,&amp;quot;(91) 555 91 99&amp;quot;)&lt;br /&gt;
9&amp;gt; INSERT Customers VALUES(&amp;quot;8&amp;quot;,&amp;quot;P&amp;quot;,&amp;quot;Leb&amp;quot;,      &amp;quot;Owner&amp;quot;,  &amp;quot;12      &amp;quot;,&amp;quot;Beijing&amp;quot;   ,NULL,&amp;quot;13008&amp;quot;, &amp;quot;France&amp;quot;, &amp;quot;91.24.45.40&amp;quot;,&amp;quot;91.24.45.41&amp;quot;)&lt;br /&gt;
10&amp;gt; INSERT Customers VALUES(&amp;quot;9&amp;quot;,&amp;quot;D&amp;quot;,&amp;quot;Elizabeth&amp;quot;,&amp;quot;Manager&amp;quot;,&amp;quot;23 Blvd.&amp;quot;,&amp;quot;Tsawassen&amp;quot;,&amp;quot;BC&amp;quot;, &amp;quot;T2F8M4&amp;quot;,&amp;quot;Canada&amp;quot;, &amp;quot;(604) 555-4729&amp;quot;,&amp;quot;(604) 555-3745&amp;quot;)&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&amp;gt;&lt;br /&gt;
2&amp;gt;    CREATE VIEW CustomerOrders_vw&lt;br /&gt;
3&amp;gt;    WITH SCHEMABINDING&lt;br /&gt;
4&amp;gt;    AS&lt;br /&gt;
5&amp;gt;    SELECT   cu.rupanyName&lt;br /&gt;
6&amp;gt;    FROM     dbo.Customers  AS cu&lt;br /&gt;
7&amp;gt;    GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt;    CREATE TRIGGER trCustomerOrderUpdate ON CustomerOrders_vw&lt;br /&gt;
5&amp;gt;    INSTEAD OF DELETE&lt;br /&gt;
6&amp;gt;    AS&lt;br /&gt;
7&amp;gt;    BEGIN&lt;br /&gt;
8&amp;gt;        IF (SELECT COUNT(*) FROM Inserted) &amp;gt; 0&lt;br /&gt;
9&amp;gt;        BEGIN&lt;br /&gt;
10&amp;gt;            RAISERROR(&amp;quot;No matching Orders. Cannot perform insert&amp;quot;,10,1)&lt;br /&gt;
11&amp;gt;        END&lt;br /&gt;
12&amp;gt;    END&lt;br /&gt;
13&amp;gt; GO&lt;br /&gt;
1&amp;gt; drop TRIGGER trCustomerOrderUpdate;&lt;br /&gt;
2&amp;gt; drop view CustomerOrders_vw;&lt;br /&gt;
3&amp;gt; drop table Customers;&lt;br /&gt;
4&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Inserted, deleted pseudo 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;
5&amp;gt;&lt;br /&gt;
6&amp;gt; CREATE TABLE Products (&lt;br /&gt;
7&amp;gt;      ProductID int NOT NULL ,&lt;br /&gt;
8&amp;gt;      ProductName nvarchar (40) NOT NULL ,&lt;br /&gt;
9&amp;gt;      SupplierID int NULL ,&lt;br /&gt;
10&amp;gt;     CategoryID int NULL ,&lt;br /&gt;
11&amp;gt;     QuantityPerUnit nvarchar (20) NULL ,&lt;br /&gt;
12&amp;gt;     UnitPrice money NULL,&lt;br /&gt;
13&amp;gt;     UnitsInStock smallint NULL,&lt;br /&gt;
14&amp;gt;     UnitsOnOrder smallint NULL,&lt;br /&gt;
15&amp;gt;     ReorderLevel smallint NULL,&lt;br /&gt;
16&amp;gt;     Discontinued bit NOT NULL&lt;br /&gt;
17&amp;gt; )&lt;br /&gt;
18&amp;gt; GO&lt;br /&gt;
1&amp;gt; INSERT Products VALUES(1,&amp;quot;F&amp;quot;,15,4,&amp;quot;10 - 999 g pkgs.&amp;quot;,61.5,66,6,6,6)&lt;br /&gt;
2&amp;gt; INSERT Products VALUES(2,&amp;quot;M&amp;quot;,14,4,&amp;quot;24 - 888 g pkgs.&amp;quot;,34.8,74,7,7,7)&lt;br /&gt;
3&amp;gt; INSERT Products VALUES(3,&amp;quot;R&amp;quot;,17,8,&amp;quot;24 - 777 g jars&amp;quot;,17,171,0,5,0)&lt;br /&gt;
4&amp;gt; INSERT Products VALUES(4,&amp;quot;L&amp;quot;,4,7,&amp;quot;5 kg pkg.&amp;quot;,10,4,20,5,0)&lt;br /&gt;
5&amp;gt; INSERT Products VALUES(5,&amp;quot;R&amp;quot;,12,1,&amp;quot;24 - 0.5 l bottles&amp;quot;,1.23,445,0,25,0)&lt;br /&gt;
6&amp;gt; INSERT Products VALUES(6,&amp;quot;L&amp;quot;,23,1,&amp;quot;500 ml&amp;quot;,18,57,1,20,0)&lt;br /&gt;
7&amp;gt; INSERT Products VALUES(7,&amp;quot;O&amp;quot;,12,2,&amp;quot;12 boxes&amp;quot;,13,23,0,15,0)&lt;br /&gt;
8&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&amp;gt;&lt;br /&gt;
2&amp;gt;    create TRIGGER ProductIsRationed&lt;br /&gt;
3&amp;gt;       ON Products&lt;br /&gt;
4&amp;gt;       FOR UPDATE&lt;br /&gt;
5&amp;gt;    AS&lt;br /&gt;
6&amp;gt;       IF UPDATE(UnitsInStock)&lt;br /&gt;
7&amp;gt;       BEGIN&lt;br /&gt;
8&amp;gt;       IF EXISTS&lt;br /&gt;
9&amp;gt;          (&lt;br /&gt;
10&amp;gt;           SELECT &amp;quot;True&amp;quot;&lt;br /&gt;
11&amp;gt;           FROM Inserted i&lt;br /&gt;
12&amp;gt;           JOIN Deleted d&lt;br /&gt;
13&amp;gt;              ON i.ProductID = d.ProductID&lt;br /&gt;
14&amp;gt;           WHERE (d.UnitsInStock - i.UnitsInStock) &amp;gt; d.UnitsInStock / 2&lt;br /&gt;
15&amp;gt;              AND d.UnitsInStock - i.UnitsInStock &amp;gt; 0&lt;br /&gt;
16&amp;gt;          )&lt;br /&gt;
17&amp;gt;       BEGIN&lt;br /&gt;
18&amp;gt;          RAISERROR(&amp;quot;Cannot reduce stock by more than 50%% at once.&amp;quot;,16,1)&lt;br /&gt;
19&amp;gt;          ROLLBACK TRAN&lt;br /&gt;
20&amp;gt;       END&lt;br /&gt;
21&amp;gt;       END&lt;br /&gt;
22&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop TRIGGER ProductIsRationed;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table Products;&lt;br /&gt;
3&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== inserted table Demo==&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;
7&amp;gt;&lt;br /&gt;
8&amp;gt; CREATE TABLE Employees&lt;br /&gt;
9&amp;gt; (&lt;br /&gt;
10&amp;gt;   empid     int          NOT NULL,&lt;br /&gt;
11&amp;gt;   mgrid     int          NULL,&lt;br /&gt;
12&amp;gt;   empname   varchar(25)  NOT NULL,&lt;br /&gt;
13&amp;gt;   salary    money        NOT NULL,&lt;br /&gt;
14&amp;gt;   lvl       int          NULL,&lt;br /&gt;
15&amp;gt;   hierarchy varchar(900) NULL&lt;br /&gt;
16&amp;gt; )&lt;br /&gt;
17&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; CREATE TRIGGER myTrigger ON Employees FOR INSERT&lt;br /&gt;
3&amp;gt; AS&lt;br /&gt;
4&amp;gt; DECLARE @numrows AS int&lt;br /&gt;
5&amp;gt; SET @numrows = @@ROWCOUNT&lt;br /&gt;
6&amp;gt; IF @numrows &amp;gt; 1&lt;br /&gt;
7&amp;gt; BEGIN&lt;br /&gt;
8&amp;gt;   RAISERROR(&amp;quot;Only single row inserts are supported!&amp;quot;, 16, 1)&lt;br /&gt;
9&amp;gt;   ROLLBACK TRAN&lt;br /&gt;
10&amp;gt; END&lt;br /&gt;
11&amp;gt; ELSE&lt;br /&gt;
12&amp;gt; IF @numrows = 1&lt;br /&gt;
13&amp;gt; BEGIN&lt;br /&gt;
14&amp;gt;   UPDATE E&lt;br /&gt;
15&amp;gt;     SET lvl = CASE&lt;br /&gt;
16&amp;gt;                 WHEN E.mgrid IS NULL THEN 0&lt;br /&gt;
17&amp;gt;                 ELSE M.lvl + 1&lt;br /&gt;
18&amp;gt;               END,&lt;br /&gt;
19&amp;gt;         hierarchy = CASE&lt;br /&gt;
20&amp;gt;                       WHEN E.mgrid IS NULL THEN &amp;quot;.&amp;quot;&lt;br /&gt;
21&amp;gt;                       ELSE M.hierarchy&lt;br /&gt;
22&amp;gt;                     END + CAST(E.empid AS varchar(10)) + &amp;quot;.&amp;quot;&lt;br /&gt;
23&amp;gt; FROM&lt;br /&gt;
24&amp;gt;     Employees AS E&lt;br /&gt;
25&amp;gt;   JOIN&lt;br /&gt;
26&amp;gt;     inserted AS I ON I.empid = E.empid&lt;br /&gt;
27&amp;gt;   LEFT OUTER JOIN&lt;br /&gt;
28&amp;gt;     Employees AS M ON E.mgrid = M.empid&lt;br /&gt;
29&amp;gt; END&lt;br /&gt;
30&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; --Testing the myTrigger Trigger&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt; INSERT INTO employees(empid, mgrid, empname, salary) VALUES(15, 12, &amp;quot;Sean&amp;quot;, $1500.00)&lt;br /&gt;
5&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; drop table Employees;&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
1&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Join Inserted table with real 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;
2&amp;gt;&lt;br /&gt;
3&amp;gt; CREATE TABLE Customers (&lt;br /&gt;
4&amp;gt;      CustomerID nchar (5) NOT NULL ,&lt;br /&gt;
5&amp;gt;      CompanyName nvarchar (40) NOT NULL ,&lt;br /&gt;
6&amp;gt;      ContactName nvarchar (30) NULL ,&lt;br /&gt;
7&amp;gt;      ContactTitle nvarchar (30) NULL ,&lt;br /&gt;
8&amp;gt;      Address nvarchar (60) NULL ,&lt;br /&gt;
9&amp;gt;      City nvarchar (15) NULL ,&lt;br /&gt;
10&amp;gt;     Region nvarchar (15) NULL ,&lt;br /&gt;
11&amp;gt;     PostalCode nvarchar (10) NULL ,&lt;br /&gt;
12&amp;gt;     Country nvarchar (15) NULL ,&lt;br /&gt;
13&amp;gt;     Phone nvarchar (24) NULL ,&lt;br /&gt;
14&amp;gt;     Fax nvarchar (24) NULL&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 Customers VALUES(&amp;quot;1&amp;quot;,&amp;quot;A&amp;quot;,&amp;quot;Maria&amp;quot;,    &amp;quot;Sales&amp;quot;,  &amp;quot;Str. 57&amp;quot;, &amp;quot;Berlin&amp;quot;    ,NULL,&amp;quot;12209&amp;quot;, &amp;quot;Germany&amp;quot;,&amp;quot;111-1111111&amp;quot;,&amp;quot;111-1111111&amp;quot;)&lt;br /&gt;
3&amp;gt; INSERT Customers VALUES(&amp;quot;2&amp;quot;,&amp;quot;M&amp;quot;,&amp;quot;Joe&amp;quot;,      &amp;quot;Owner&amp;quot;,  &amp;quot;Ave. 231&amp;quot;,&amp;quot;Vancouver&amp;quot; ,NULL,&amp;quot;05023&amp;quot;, &amp;quot;Mexico&amp;quot;, &amp;quot;(222) 222-3332&amp;quot;,NULL)&lt;br /&gt;
4&amp;gt; INSERT Customers VALUES(&amp;quot;3&amp;quot;,&amp;quot;H&amp;quot;,&amp;quot;Thomas&amp;quot;,   &amp;quot;Sales&amp;quot;,  &amp;quot;Sq.  111&amp;quot;,&amp;quot;London&amp;quot;    ,NULL,&amp;quot;1D00P&amp;quot;, &amp;quot;UK&amp;quot;,     &amp;quot;(444) 444-4444&amp;quot;,&amp;quot;(444) 444-4444&amp;quot;)&lt;br /&gt;
5&amp;gt; INSERT Customers VALUES(&amp;quot;4&amp;quot;,&amp;quot;B&amp;quot;,&amp;quot;Berg&amp;quot;,     &amp;quot;Order&amp;quot;,  &amp;quot;Blv    8&amp;quot;,&amp;quot;Toronto&amp;quot;   ,NULL,&amp;quot;00222&amp;quot;, &amp;quot;Sweden&amp;quot;, &amp;quot;4444-55 55 65&amp;quot;,&amp;quot;5555-55 55 55&amp;quot;)&lt;br /&gt;
6&amp;gt; INSERT Customers VALUES(&amp;quot;5&amp;quot;,&amp;quot;S&amp;quot;,&amp;quot;Moos&amp;quot;,     &amp;quot;Sales&amp;quot;,  &amp;quot;Fort  57&amp;quot;,&amp;quot;New York&amp;quot;  ,NULL,&amp;quot;68306&amp;quot;, &amp;quot;Germany&amp;quot;,&amp;quot;6666-66666&amp;quot;,&amp;quot;6666-77777&amp;quot;)&lt;br /&gt;
7&amp;gt; INSERT Customers VALUES(&amp;quot;6&amp;quot;,&amp;quot;F&amp;quot;,&amp;quot;Cite&amp;quot;,     &amp;quot;Manager&amp;quot;,&amp;quot;24      &amp;quot;,&amp;quot;Dalles&amp;quot;    ,NULL,&amp;quot;67000&amp;quot;, &amp;quot;France&amp;quot;, &amp;quot;88.60.15.31&amp;quot;,&amp;quot;88.60.15.32&amp;quot;)&lt;br /&gt;
8&amp;gt; INSERT Customers VALUES(&amp;quot;7&amp;quot;,&amp;quot;C&amp;quot;,&amp;quot;Sommer&amp;quot;,   &amp;quot;Owner&amp;quot;,  &amp;quot;Araq, 67&amp;quot;,&amp;quot;Paris&amp;quot;     ,NULL,&amp;quot;28023&amp;quot;, &amp;quot;Spain&amp;quot;,  &amp;quot;(91) 555 22 82&amp;quot;,&amp;quot;(91) 555 91 99&amp;quot;)&lt;br /&gt;
9&amp;gt; INSERT Customers VALUES(&amp;quot;8&amp;quot;,&amp;quot;P&amp;quot;,&amp;quot;Leb&amp;quot;,      &amp;quot;Owner&amp;quot;,  &amp;quot;12      &amp;quot;,&amp;quot;Beijing&amp;quot;   ,NULL,&amp;quot;13008&amp;quot;, &amp;quot;France&amp;quot;, &amp;quot;91.24.45.40&amp;quot;,&amp;quot;91.24.45.41&amp;quot;)&lt;br /&gt;
10&amp;gt; INSERT Customers VALUES(&amp;quot;9&amp;quot;,&amp;quot;D&amp;quot;,&amp;quot;Elizabeth&amp;quot;,&amp;quot;Manager&amp;quot;,&amp;quot;23 Blvd.&amp;quot;,&amp;quot;Tsawassen&amp;quot;,&amp;quot;BC&amp;quot;, &amp;quot;T2F8M4&amp;quot;,&amp;quot;Canada&amp;quot;, &amp;quot;(604) 555-4729&amp;quot;,&amp;quot;(604) 555-3745&amp;quot;)&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&amp;gt;&lt;br /&gt;
2&amp;gt; CREATE TABLE Orders (&lt;br /&gt;
3&amp;gt;      OrderID int IDENTITY (1, 1) NOT NULL ,&lt;br /&gt;
4&amp;gt;      CustomerID nchar (5) NULL ,&lt;br /&gt;
5&amp;gt;      EmployeeID int NULL ,&lt;br /&gt;
6&amp;gt;      OrderDate datetime NULL ,&lt;br /&gt;
7&amp;gt;      RequiredDate datetime NULL ,&lt;br /&gt;
8&amp;gt;      ShippedDate datetime NULL ,&lt;br /&gt;
9&amp;gt;      ShipVia int NULL ,&lt;br /&gt;
10&amp;gt;     Freight money NULL DEFAULT (0),&lt;br /&gt;
11&amp;gt;     ShipName nvarchar (40) NULL ,&lt;br /&gt;
12&amp;gt;     ShipAddress nvarchar (60) NULL ,&lt;br /&gt;
13&amp;gt;     ShipCity nvarchar (15) NULL ,&lt;br /&gt;
14&amp;gt;     ShipRegion nvarchar (15) NULL ,&lt;br /&gt;
15&amp;gt;     ShipPostalCode nvarchar (10) NULL ,&lt;br /&gt;
16&amp;gt;     ShipCountry nvarchar (15) NULL)&lt;br /&gt;
17&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;    create TRIGGER OrderHasCustomer&lt;br /&gt;
3&amp;gt;       ON Orders&lt;br /&gt;
4&amp;gt;       FOR INSERT, UPDATE&lt;br /&gt;
5&amp;gt;    AS&lt;br /&gt;
6&amp;gt;       IF EXISTS&lt;br /&gt;
7&amp;gt;          (&lt;br /&gt;
8&amp;gt;           SELECT &amp;quot;True&amp;quot;&lt;br /&gt;
9&amp;gt;           FROM Inserted i&lt;br /&gt;
10&amp;gt;           LEFT JOIN Customers c&lt;br /&gt;
11&amp;gt;              ON i.CustomerID = c.CustomerID&lt;br /&gt;
12&amp;gt;           WHERE c.CustomerID IS NULL&lt;br /&gt;
13&amp;gt;          )&lt;br /&gt;
14&amp;gt;       BEGIN&lt;br /&gt;
15&amp;gt;          RAISERROR(60000,16,1,&amp;quot;CustomerID&amp;quot;,&amp;quot;Orders&amp;quot;,&amp;quot;CustomerID&amp;quot;,&amp;quot;Customers&amp;quot;)&lt;br /&gt;
16&amp;gt;          ROLLBACK TRAN&lt;br /&gt;
17&amp;gt;       END&lt;br /&gt;
18&amp;gt;       GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop TRIGGER OrderHasCustomer;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table Customers;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt; drop table orders;&lt;br /&gt;
2&amp;gt; GO&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>