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

	<entry>
		<id>http://sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Constraints/Constriant_violation&amp;diff=7015&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/Constraints/Constriant_violation&amp;diff=7015&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/Constraints/Constriant_violation&amp;diff=7016&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/Constraints/Constriant_violation&amp;diff=7016&amp;oldid=prev"/>
				<updated>2010-05-26T10:24:59Z</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 NOT NULL phrase adds a constraint to restrict the input of rows with a null 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;
5&amp;gt;&lt;br /&gt;
6&amp;gt; CREATE TABLE T (&lt;br /&gt;
7&amp;gt;     int1 int IDENTITY PRIMARY KEY,&lt;br /&gt;
8&amp;gt;     vch1 varchar(5)&lt;br /&gt;
9&amp;gt;         CHECK (LEN(vch1) &amp;gt; 0)&lt;br /&gt;
10&amp;gt;          NOT NULL,&lt;br /&gt;
11&amp;gt;      vch2 varchar(5)&lt;br /&gt;
12&amp;gt;          CONSTRAINT CK_LEN_TOO_SHORT&lt;br /&gt;
13&amp;gt;          CHECK (LEN(vch2) &amp;gt; 0)&lt;br /&gt;
14&amp;gt;          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 T (vch1) VALUES(&amp;quot;40222&amp;quot;)&lt;br /&gt;
3&amp;gt; INSERT T (vch1) VALUES(&amp;quot;4022&amp;quot;)&lt;br /&gt;
4&amp;gt; INSERT T (vch1) VALUES(&amp;quot;r0222&amp;quot;)&lt;br /&gt;
5&amp;gt; INSERT T DEFAULT VALUES&lt;br /&gt;
6&amp;gt; GO&lt;br /&gt;
Msg 515, Level 16, State 2, Server J\SQLEXPRESS, Line 2&lt;br /&gt;
Cannot insert the value NULL into column &amp;quot;vch2&amp;quot;, table &amp;quot;master.dbo.T&amp;quot;; column does not allow nulls. INSERT fails.&lt;br /&gt;
The statement has been terminated.&lt;br /&gt;
Msg 515, Level 16, State 2, Server J\SQLEXPRESS, Line 3&lt;br /&gt;
Cannot insert the value NULL into column &amp;quot;vch2&amp;quot;, table &amp;quot;master.dbo.T&amp;quot;; column does not allow nulls. INSERT fails.&lt;br /&gt;
The statement has been terminated.&lt;br /&gt;
Msg 515, Level 16, State 2, Server J\SQLEXPRESS, Line 4&lt;br /&gt;
Cannot insert the value NULL into column &amp;quot;vch2&amp;quot;, table &amp;quot;master.dbo.T&amp;quot;; column does not allow nulls. INSERT fails.&lt;br /&gt;
The statement has been terminated.&lt;br /&gt;
Msg 515, Level 16, State 2, Server J\SQLEXPRESS, Line 5&lt;br /&gt;
Cannot insert the value NULL into column &amp;quot;vch1&amp;quot;, table &amp;quot;master.dbo.T&amp;quot;; column does not allow nulls. INSERT fails.&lt;br /&gt;
The statement has been terminated.&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; drop table t;&lt;br /&gt;
4&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;
== Exception in a transaction==&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 MySavings(&lt;br /&gt;
3&amp;gt;     AccountNum Int NOT NULL,&lt;br /&gt;
4&amp;gt;     Amount Money NOT NULL&lt;br /&gt;
5&amp;gt; );&lt;br /&gt;
6&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; CREATE TABLE MyChecking(&lt;br /&gt;
3&amp;gt;     AcountNum Int NOT NULL,&lt;br /&gt;
4&amp;gt;     Amount Money NOT NULL&lt;br /&gt;
5&amp;gt; );&lt;br /&gt;
6&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; ALTER TABLE MyChecking ADD CONSTRAINT ckMinBalance&lt;br /&gt;
3&amp;gt; CHECK (Amount &amp;gt; $100.00)&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
1&amp;gt; INSERT MySavings VALUES (12345, $1000.00)&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; INSERT MyChecking VALUES (12345, $1000.00)&lt;br /&gt;
3&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; BEGIN TRANSACTION&lt;br /&gt;
4&amp;gt; UPDATE MyChecking SET Amount = Amount - $990.00&lt;br /&gt;
5&amp;gt; WHERE AcountNum = 12345&lt;br /&gt;
6&amp;gt; UPDATE MySavings SET Amount = Amount + $990.00&lt;br /&gt;
7&amp;gt; WHERE AccountNum = 12345&lt;br /&gt;
8&amp;gt; COMMIT TRANSACTION&lt;br /&gt;
9&amp;gt; GO&lt;br /&gt;
Msg 547, Level 16, State 1, Server J\SQLEXPRESS, Line 4&lt;br /&gt;
The UPDATE statement conflicted with the CHECK constraint &amp;quot;ckMinBalance&amp;quot;. The conflict occurred in database &amp;quot;master&amp;quot;, table &amp;quot;dbo.MyChecking&amp;quot;, column &amp;quot;Amount&amp;quot;.&lt;br /&gt;
The statement has been terminated.&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table MySavings;&lt;br /&gt;
3&amp;gt; drop table MyChecking;&lt;br /&gt;
4&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Trap Both Primary Key and CHECK Constraint Violations==&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 T1(&lt;br /&gt;
9&amp;gt;   pk_col    int NOT NULL PRIMARY KEY CHECK (pk_col &amp;gt; 0),&lt;br /&gt;
10&amp;gt;   ident_col int NOT NULL IDENTITY (1,1)&lt;br /&gt;
11&amp;gt; )&lt;br /&gt;
12&amp;gt;&lt;br /&gt;
13&amp;gt; DECLARE&lt;br /&gt;
14&amp;gt;   @myerror    AS int&lt;br /&gt;
15&amp;gt; INSERT INTO T1 VALUES(0) -- violate the check constraint&lt;br /&gt;
16&amp;gt; SET @myerror = @@ERROR&lt;br /&gt;
17&amp;gt; IF @myerror = 2627&lt;br /&gt;
18&amp;gt;   PRINT &amp;quot;PRIMARY KEY constraint violation&amp;quot;&lt;br /&gt;
19&amp;gt; ELSE IF @myerror = 547&lt;br /&gt;
20&amp;gt;   PRINT &amp;quot;CHECK constraint violation&amp;quot;&lt;br /&gt;
21&amp;gt; GO&lt;br /&gt;
Msg 547, Level 16, State 1, Server J\SQLEXPRESS, Line 15&lt;br /&gt;
The INSERT statement conflicted with the CHECK constraint &amp;quot;CK__T1__pk_col__39788055&amp;quot;. The conflict occurred in database &amp;quot;master&amp;quot;, table &amp;quot;dbo.T1&amp;quot;, column &amp;quot;pk_col&amp;quot;.&lt;br /&gt;
The statement has been terminated.&lt;br /&gt;
CHECK constraint violation&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; --Attempt to Capture @@IDENTITY, @@ROWCOUNT, and @@ERROR&lt;br /&gt;
3&amp;gt; DECLARE&lt;br /&gt;
4&amp;gt;   @myerror    AS int,&lt;br /&gt;
5&amp;gt;   @myrowcount AS int,&lt;br /&gt;
6&amp;gt;   @myidentity AS int&lt;br /&gt;
7&amp;gt; INSERT INTO T1 VALUES(10) -- PK violation&lt;br /&gt;
8&amp;gt; SELECT @myidentity = @@IDENTITY,&lt;br /&gt;
9&amp;gt;        @myrowcount = @@ROWCOUNT,&lt;br /&gt;
10&amp;gt;        @myerror    = @@ERROR&lt;br /&gt;
11&amp;gt; PRINT &amp;quot;@myidentity: &amp;quot; + CAST(@myidentity AS varchar)&lt;br /&gt;
12&amp;gt; PRINT &amp;quot;@myrowcount: &amp;quot; + CAST(@myrowcount AS varchar)&lt;br /&gt;
13&amp;gt; PRINT &amp;quot;@myerror   : &amp;quot; + CAST(@myerror AS varchar)&lt;br /&gt;
14&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
@myidentity: 2&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
@myrowcount: 1&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
@myerror   : 0&lt;br /&gt;
1&amp;gt; --Output of Successful Attempt to Capture @@IDENTITY, @@ROWCOUNT, and @@ERROR&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; drop table T1;&lt;br /&gt;
4&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Update statement and check-constraints==&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; CREATE TABLE MySavings(&lt;br /&gt;
5&amp;gt;     AccountNum Int NOT NULL,&lt;br /&gt;
6&amp;gt;     Amount Money NOT NULL&lt;br /&gt;
7&amp;gt; );&lt;br /&gt;
8&amp;gt; GO&lt;br /&gt;
1&amp;gt; CREATE TABLE MyChecking(&lt;br /&gt;
2&amp;gt;     AcountNum Int NOT NULL,&lt;br /&gt;
3&amp;gt;     Amount Money NOT NULL&lt;br /&gt;
4&amp;gt; );&lt;br /&gt;
5&amp;gt; GO&lt;br /&gt;
1&amp;gt; ALTER TABLE MyChecking ADD CONSTRAINT ckMinBalance&lt;br /&gt;
2&amp;gt; CHECK (Amount &amp;gt; $100.00)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt; INSERT MySavings VALUES (12345, $1000.00)&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&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; INSERT MyChecking VALUES (12345, $1000.00)&lt;br /&gt;
5&amp;gt;&lt;br /&gt;
6&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; BEGIN TRANSACTION&lt;br /&gt;
5&amp;gt; UPDATE MyChecking SET Amount = Amount - $990.00&lt;br /&gt;
6&amp;gt; WHERE AcountNum = 12345&lt;br /&gt;
7&amp;gt; UPDATE MySavings SET Amount = Amount + $990.00&lt;br /&gt;
8&amp;gt; WHERE AccountNum = 12345&lt;br /&gt;
9&amp;gt; COMMIT TRANSACTION&lt;br /&gt;
10&amp;gt; GO&lt;br /&gt;
Msg 547, Level 16, State 1, Server J\SQLEXPRESS, Line 5&lt;br /&gt;
The UPDATE statement conflicted with the CHECK constraint &amp;quot;ckMinBalance&amp;quot;. The conflict occurred in database &amp;quot;master&amp;quot;, table &amp;quot;dbo.MyChecking&amp;quot;, column &amp;quot;Amount&amp;quot;.&lt;br /&gt;
The statement has been terminated.&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; BEGIN TRANSACTION&lt;br /&gt;
6&amp;gt;  UPDATE MyChecking SET Amount = Amount - $990.00&lt;br /&gt;
7&amp;gt;  IF @@ERROR != 0&lt;br /&gt;
8&amp;gt;    BEGIN&lt;br /&gt;
9&amp;gt;     ROLLBACK TRANSACTION&lt;br /&gt;
10&amp;gt;     RETURN&lt;br /&gt;
11&amp;gt;     END&lt;br /&gt;
12&amp;gt;    ELSE&lt;br /&gt;
13&amp;gt;   UPDATE MySavings SET Amount = Amount + $990.00&lt;br /&gt;
14&amp;gt;   IF @@ERROR != 0&lt;br /&gt;
15&amp;gt;     BEGIN&lt;br /&gt;
16&amp;gt;      ROLLBACK TRANSACTION&lt;br /&gt;
17&amp;gt;      RETURN&lt;br /&gt;
18&amp;gt;     END&lt;br /&gt;
19&amp;gt;    ELSE&lt;br /&gt;
20&amp;gt;  COMMIT TRANSACTION&lt;br /&gt;
21&amp;gt;  GO&lt;br /&gt;
Msg 547, Level 16, State 1, Server J\SQLEXPRESS, Line 6&lt;br /&gt;
The UPDATE statement conflicted with the CHECK constraint &amp;quot;ckMinBalance&amp;quot;. The conflict occurred in database &amp;quot;master&amp;quot;, table &amp;quot;dbo.MyChecking&amp;quot;, column &amp;quot;Amount&amp;quot;.&lt;br /&gt;
The statement has been terminated.&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table MySavings;&lt;br /&gt;
3&amp;gt; drop table MyChecking;&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
1&amp;gt;&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>