<?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%2FTransaction%2FTRANSACTION_ISOLATION_LEVEL</id>
		<title>SQL Server/T-SQL Tutorial/Transaction/TRANSACTION ISOLATION LEVEL - История изменений</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%2FTransaction%2FTRANSACTION_ISOLATION_LEVEL"/>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Transaction/TRANSACTION_ISOLATION_LEVEL&amp;action=history"/>
		<updated>2026-05-24T04:07:53Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Transaction/TRANSACTION_ISOLATION_LEVEL&amp;diff=6891&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/Transaction/TRANSACTION_ISOLATION_LEVEL&amp;diff=6891&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/Transaction/TRANSACTION_ISOLATION_LEVEL&amp;diff=6892&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/Transaction/TRANSACTION_ISOLATION_LEVEL&amp;diff=6892&amp;oldid=prev"/>
				<updated>2010-05-26T10:24:41Z</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;== SET TRANSACTION ISOLATION LEVEL SERIALIZABLE==&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 Product(&lt;br /&gt;
3&amp;gt;     ProductID               int                NOT NULL,&lt;br /&gt;
4&amp;gt;     Name                    nvarchar(25)       NOT NULL,&lt;br /&gt;
5&amp;gt;     ProductNumber           nvarchar(25)               ,&lt;br /&gt;
6&amp;gt;      Color                   nvarchar(15)       NULL,&lt;br /&gt;
7&amp;gt;      StandardCost            money              NOT NULL,&lt;br /&gt;
8&amp;gt;      Size                    nvarchar(5)        NULL,&lt;br /&gt;
9&amp;gt;      Weight                  decimal(8, 2)      NULL,&lt;br /&gt;
10&amp;gt;      ProductLine             nchar(20)           NULL,&lt;br /&gt;
11&amp;gt;      SellStartDate           datetime           NOT NULL,&lt;br /&gt;
12&amp;gt;      SellEndDate             datetime           NULL&lt;br /&gt;
13&amp;gt;  )&lt;br /&gt;
14&amp;gt;  GO&lt;br /&gt;
1&amp;gt; insert into Product values(1,&amp;quot;Product A&amp;quot;, &amp;quot;1&amp;quot;,&amp;quot;Red&amp;quot;,123.123,&amp;quot;1&amp;quot;,1,&amp;quot;ProductLine A&amp;quot;,&amp;quot;1999-03-22&amp;quot;,&amp;quot;2000-03-22&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; insert into Product values(2,&amp;quot;Product B&amp;quot;, &amp;quot;2&amp;quot;,&amp;quot;Yellow&amp;quot;,234.234,&amp;quot;1&amp;quot;,3,&amp;quot;ProductLine B&amp;quot;,&amp;quot;2000-03-22&amp;quot;,&amp;quot;2001-03-22&amp;quot;);&lt;br /&gt;
4&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; insert into Product values(3,&amp;quot;Product C&amp;quot;, &amp;quot;3&amp;quot;,&amp;quot;Pink&amp;quot;,345.345,&amp;quot;1&amp;quot;,3,&amp;quot;ProductLine V&amp;quot;,&amp;quot;2001-09-22&amp;quot;,&amp;quot;2006-02-22&amp;quot;);&lt;br /&gt;
4&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; insert into Product values(4,&amp;quot;Product D&amp;quot;, &amp;quot;4&amp;quot;,&amp;quot;White&amp;quot;,456.456,&amp;quot;1&amp;quot;,4,&amp;quot;ProductLine D&amp;quot;,&amp;quot;2002-08-22&amp;quot;,&amp;quot;2006-03-22&amp;quot;);&lt;br /&gt;
4&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; insert into Product values(5,&amp;quot;Product E&amp;quot;, &amp;quot;5&amp;quot;,&amp;quot;Black&amp;quot;,567.567,&amp;quot;1&amp;quot;,5,&amp;quot;ProductLine E&amp;quot;,&amp;quot;2003-01-22&amp;quot;,&amp;quot;2003-04-22&amp;quot;);&lt;br /&gt;
4&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; insert into Product values(6,&amp;quot;Product F&amp;quot;, &amp;quot;6&amp;quot;,&amp;quot;Blue&amp;quot;,678.678,&amp;quot;1&amp;quot;,6,&amp;quot;ProductLine W&amp;quot;,&amp;quot;2004-02-22&amp;quot;,&amp;quot;2005-05-22&amp;quot;);&lt;br /&gt;
4&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; insert into Product values(7,&amp;quot;Product G&amp;quot;, &amp;quot;7&amp;quot;,&amp;quot;Drak&amp;quot;,789.789,&amp;quot;1&amp;quot;,7,&amp;quot;ProductLine Q&amp;quot;,&amp;quot;2005-03-22&amp;quot;,&amp;quot;2006-03-22&amp;quot;);&lt;br /&gt;
4&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; insert into Product values(8,&amp;quot;Product H&amp;quot;, &amp;quot;8&amp;quot;,&amp;quot;Gray&amp;quot;,234.123,&amp;quot;1&amp;quot;,8,&amp;quot;ProductLine F&amp;quot;,&amp;quot;2006-04-22&amp;quot;,&amp;quot;2006-09-22&amp;quot;);&lt;br /&gt;
4&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; insert into Product values(9,&amp;quot;Product I&amp;quot;, &amp;quot;9&amp;quot;,&amp;quot;Red&amp;quot;,543.123,&amp;quot;1&amp;quot;,9,&amp;quot;ProductLine R&amp;quot;,&amp;quot;2007-05-22&amp;quot;,&amp;quot;2008-03-22&amp;quot;);&lt;br /&gt;
4&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; insert into Product values(0,&amp;quot;Product J&amp;quot;, &amp;quot;0&amp;quot;,&amp;quot;Gold&amp;quot;,765.123,&amp;quot;1&amp;quot;,0,&amp;quot;ProductLine J&amp;quot;,&amp;quot;2008-06-22&amp;quot;,&amp;quot;2009-03-22&amp;quot;);&lt;br /&gt;
4&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;&lt;br /&gt;
4&amp;gt;&lt;br /&gt;
5&amp;gt; SET TRANSACTION ISOLATION LEVEL SERIALIZABLE&lt;br /&gt;
6&amp;gt; GO&lt;br /&gt;
1&amp;gt; BEGIN TRANSACTION&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
1&amp;gt;   UPDATE Product SET StandardCost = StandardCost * 1.15&lt;br /&gt;
2&amp;gt;   WHERE ProductID = 1&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;   UPDATE Product SET StandardCost = StandardCost * 1.15&lt;br /&gt;
2&amp;gt;   WHERE ProductID = 1&lt;br /&gt;
3&amp;gt;     AND StandardCost &amp;lt; 1000&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; COMMIT TRANSACTION&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; drop table Product;&lt;br /&gt;
4&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Syntax for SET TRANSACTION ISOLATION LEVEL==&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;
SET TRANSACTION ISOLATION LEVEL&lt;br /&gt;
  { READ COMMITTED&lt;br /&gt;
    | READ UNCOMMITTED&lt;br /&gt;
    | REPEATABLE READ&lt;br /&gt;
    | SERIALIZABLE&lt;br /&gt;
}&lt;br /&gt;
The READ UNCOMMITTED option allows dirty reads.&lt;br /&gt;
It is the same as using the NOLOCK or READUNCOMMITTED table hint.&lt;br /&gt;
It does not create locks nor does it honor any locks. &lt;br /&gt;
The data you read while it is in effect may be in the process of being changed. &lt;br /&gt;
The REPEATABLE READ option additionally disallows phantom rows. &lt;br /&gt;
Shared locks remain in place for the duration of the transaction. &lt;br /&gt;
The outside process can still insert rows that will be picked up by your second SELECT. &lt;br /&gt;
The SERIALIZABLE option is the most restrictive. &lt;br /&gt;
It additionally prevents other processes from inserting rows between your first and second SELECTs. &lt;br /&gt;
If the INSERT will make no difference to your two SELECTs, it is allowed; otherwise, it is not. &lt;br /&gt;
Reference:&lt;br /&gt;
Advanced Transact-SQL for SQL Server 2000&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Testing transaction isolation levels.==&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;
6&amp;gt;&lt;br /&gt;
7&amp;gt; CREATE TABLE authors(&lt;br /&gt;
8&amp;gt;    au_id          varchar(11),&lt;br /&gt;
9&amp;gt;    au_lname       varchar(40)       NOT NULL,&lt;br /&gt;
10&amp;gt;    au_fname       varchar(20)       NOT NULL,&lt;br /&gt;
11&amp;gt;    phone          char(12)          NOT NULL DEFAULT (&amp;quot;UNKNOWN&amp;quot;),&lt;br /&gt;
12&amp;gt;    address        varchar(40)           NULL,&lt;br /&gt;
13&amp;gt;    city           varchar(20)           NULL,&lt;br /&gt;
14&amp;gt;    state          char(2)               NULL,&lt;br /&gt;
15&amp;gt;    zip            char(5)               NULL,&lt;br /&gt;
16&amp;gt;    contract       bit               NOT NULL&lt;br /&gt;
17&amp;gt; )&lt;br /&gt;
18&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;&lt;br /&gt;
3&amp;gt; SET TRANSACTION ISOLATION LEVEL REPEATABLE READ&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; BEGIN TRAN&lt;br /&gt;
3&amp;gt; SELECT    *&lt;br /&gt;
4&amp;gt; FROM      authors&lt;br /&gt;
5&amp;gt; WHERE     au_lname = &amp;quot;Green&amp;quot;&lt;br /&gt;
6&amp;gt; WAITFOR DELAY &amp;quot;00:02:00&amp;quot;&lt;br /&gt;
7&amp;gt; ROLLBACK TRAN&lt;br /&gt;
8&amp;gt; GO&lt;br /&gt;
drop table authors;&lt;br /&gt;
GO&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>