<?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=SQL_Server%2FT-SQL_Tutorial%2FTrigger%2FUpdate_function</id>
		<title>SQL Server/T-SQL Tutorial/Trigger/Update function - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://sqle.ru/index.php?action=history&amp;feed=atom&amp;title=SQL_Server%2FT-SQL_Tutorial%2FTrigger%2FUpdate_function"/>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Trigger/Update_function&amp;action=history"/>
		<updated>2026-04-06T12:05:21Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Trigger/Update_function&amp;diff=6800&amp;oldid=prev</id>
		<title> в 13:46, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Trigger/Update_function&amp;diff=6800&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://sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Trigger/Update_function&amp;diff=6801&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Trigger/Update_function&amp;diff=6801&amp;oldid=prev"/>
				<updated>2010-05-26T10:24:12Z</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;== Get day from a datetime value==&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;
create FUNCTION DayOnly(@Date datetime)&lt;br /&gt;
   RETURNS varchar(12)&lt;br /&gt;
   WITH SCHEMABINDING&lt;br /&gt;
   AS&lt;br /&gt;
   BEGIN&lt;br /&gt;
      RETURN CONVERT(varchar(12), @Date, 101)&lt;br /&gt;
   END&lt;br /&gt;
   GO&lt;br /&gt;
drop FUNCTION DayOnly;&lt;br /&gt;
GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Is UPDATing a certain column==&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; CREATE TABLE titles(&lt;br /&gt;
5&amp;gt;    title_id       varchar(20),&lt;br /&gt;
6&amp;gt;    title          varchar(80)       NOT NULL,&lt;br /&gt;
7&amp;gt;    type           char(12)          NOT NULL,&lt;br /&gt;
8&amp;gt;    pub_id         char(4)               NULL,&lt;br /&gt;
9&amp;gt;    price          money                 NULL,&lt;br /&gt;
10&amp;gt;    advance        money                 NULL,&lt;br /&gt;
11&amp;gt;    royalty        int                   NULL,&lt;br /&gt;
12&amp;gt;    ytd_sales      int                   NULL,&lt;br /&gt;
13&amp;gt;    notes          varchar(200)          NULL,&lt;br /&gt;
14&amp;gt;    pubdate        datetime          NOT 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 titles values (&amp;quot;1&amp;quot;, &amp;quot;Secrets&amp;quot;,   &amp;quot;popular_comp&amp;quot;, &amp;quot;1389&amp;quot;, $20.00, $8000.00, 10, 4095,&amp;quot;Note 1&amp;quot;,&amp;quot;06/12/94&amp;quot;)&lt;br /&gt;
3&amp;gt; insert titles values (&amp;quot;2&amp;quot;, &amp;quot;The&amp;quot;,       &amp;quot;business&amp;quot;,     &amp;quot;1389&amp;quot;, $19.99, $5000.00, 10, 4095,&amp;quot;Note 2&amp;quot;,&amp;quot;06/12/91&amp;quot;)&lt;br /&gt;
4&amp;gt; insert titles values (&amp;quot;3&amp;quot;, &amp;quot;Emotional&amp;quot;, &amp;quot;psychology&amp;quot;,   &amp;quot;0736&amp;quot;, $7.99,  $4000.00, 10, 3336,&amp;quot;Note 3&amp;quot;,&amp;quot;06/12/91&amp;quot;)&lt;br /&gt;
5&amp;gt; insert titles values (&amp;quot;4&amp;quot;, &amp;quot;Prolonged&amp;quot;, &amp;quot;psychology&amp;quot;,   &amp;quot;0736&amp;quot;, $19.99, $2000.00, 10, 4072,&amp;quot;Note 4&amp;quot;,&amp;quot;06/12/91&amp;quot;)&lt;br /&gt;
6&amp;gt; insert titles values (&amp;quot;5&amp;quot;, &amp;quot;With&amp;quot;,      &amp;quot;business&amp;quot;,     &amp;quot;1389&amp;quot;, $11.95, $5000.00, 10, 3876,&amp;quot;Note 5&amp;quot;,&amp;quot;06/09/91&amp;quot;)&lt;br /&gt;
7&amp;gt; insert titles values (&amp;quot;6&amp;quot;, &amp;quot;Valley&amp;quot;,    &amp;quot;mod_cook&amp;quot;,     &amp;quot;0877&amp;quot;, $19.99, $0.00,    12, 2032,&amp;quot;Note 6&amp;quot;,&amp;quot;06/09/91&amp;quot;)&lt;br /&gt;
8&amp;gt; insert titles values (&amp;quot;7&amp;quot;, &amp;quot;Any?&amp;quot;,      &amp;quot;trad_cook&amp;quot;,    &amp;quot;0877&amp;quot;, $14.99, $8000.00, 10, 4095,&amp;quot;Note 7&amp;quot;,&amp;quot;06/12/91&amp;quot;)&lt;br /&gt;
9&amp;gt; insert titles values (&amp;quot;8&amp;quot;, &amp;quot;Fifty&amp;quot;,     &amp;quot;trad_cook&amp;quot;,    &amp;quot;0877&amp;quot;, $11.95, $4000.00, 14, 1509,&amp;quot;Note 8&amp;quot;,&amp;quot;06/12/91&amp;quot;)&lt;br /&gt;
10&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&amp;gt; CREATE TABLE sales(&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       varchar(80)&lt;br /&gt;
8&amp;gt; )&lt;br /&gt;
9&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;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; CREATE TABLE stores(&lt;br /&gt;
4&amp;gt;    stor_id        char(4)           NOT NULL,&lt;br /&gt;
5&amp;gt;    stor_name      varchar(40)           NULL,&lt;br /&gt;
6&amp;gt;    stor_address   varchar(40)           NULL,&lt;br /&gt;
7&amp;gt;    city           varchar(20)           NULL,&lt;br /&gt;
8&amp;gt;    state          char(2)               NULL,&lt;br /&gt;
9&amp;gt;    zip            char(5)               NULL&lt;br /&gt;
10&amp;gt; )&lt;br /&gt;
11&amp;gt; GO&lt;br /&gt;
1&amp;gt; insert stores values(&amp;quot;1&amp;quot;,&amp;quot;B&amp;quot;,&amp;quot;567 Ave.&amp;quot;,&amp;quot;Tustin&amp;quot;,   &amp;quot;CA&amp;quot;,&amp;quot;92789&amp;quot;)&lt;br /&gt;
2&amp;gt; insert stores values(&amp;quot;2&amp;quot;,&amp;quot;N&amp;quot;,&amp;quot;577 St.&amp;quot;, &amp;quot;Los Gatos&amp;quot;,&amp;quot;CA&amp;quot;,&amp;quot;96745&amp;quot;)&lt;br /&gt;
3&amp;gt; insert stores values(&amp;quot;3&amp;quot;,&amp;quot;T&amp;quot;,&amp;quot;679 St.&amp;quot;, &amp;quot;Portland&amp;quot;, &amp;quot;OR&amp;quot;,&amp;quot;89076&amp;quot;)&lt;br /&gt;
4&amp;gt; insert stores values(&amp;quot;4&amp;quot;,&amp;quot;F&amp;quot;,&amp;quot;89  St.&amp;quot;, &amp;quot;Fremont&amp;quot;,  &amp;quot;CA&amp;quot;,&amp;quot;90019&amp;quot;)&lt;br /&gt;
5&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&amp;gt;&lt;br /&gt;
2&amp;gt;     ALTER TABLE sales&lt;br /&gt;
3&amp;gt;     ADD title VARCHAR(80) NULL&lt;br /&gt;
4&amp;gt;     GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;     CREATE TRIGGER myTrigger ON titles&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(title)&lt;br /&gt;
10&amp;gt;                 BEGIN&lt;br /&gt;
11&amp;gt;                     UPDATE sales SET sales.title = inserted.title&lt;br /&gt;
12&amp;gt;                         FROM inserted INNER JOIN sales&lt;br /&gt;
13&amp;gt;                         ON inserted.title_id = sales.title_id&lt;br /&gt;
14&amp;gt;                 END&lt;br /&gt;
15&amp;gt;         END&lt;br /&gt;
16&amp;gt;     GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;     drop TRIGGER myTrigger;&lt;br /&gt;
4&amp;gt;     drop table sales;&lt;br /&gt;
5&amp;gt;     drop table titles;&lt;br /&gt;
6&amp;gt;     drop table stores;&lt;br /&gt;
7&amp;gt;     GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== The UPDATE() Function==&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;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>