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

	<entry>
		<id>http://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Constraints/Default&amp;diff=7027&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/Constraints/Default&amp;diff=7027&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/Constraints/Default&amp;diff=7028&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/Constraints/Default&amp;diff=7028&amp;oldid=prev"/>
				<updated>2010-05-26T10:25:02Z</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;== Column with default random 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;
3&amp;gt; CREATE TABLE random_data&lt;br /&gt;
4&amp;gt; (&lt;br /&gt;
5&amp;gt; col1    int      PRIMARY KEY IDENTITY(10,10) NOT NULL,&lt;br /&gt;
6&amp;gt; col2    int      NOT NULL DEFAULT CASE&lt;br /&gt;
7&amp;gt;                  -- Random integer between -9999 and 9999&lt;br /&gt;
8&amp;gt;                  WHEN CONVERT(int, RAND() * 1000) % 2 = 1&lt;br /&gt;
9&amp;gt;                  THEN (CONVERT(int, RAND() * 100000) % 10000 * -1 )&lt;br /&gt;
10&amp;gt;                  ELSE CONVERT(int, RAND() * 100000) % 10000&lt;br /&gt;
11&amp;gt;                  END,&lt;br /&gt;
12&amp;gt; col3    char(15) NOT NULL DEFAULT&lt;br /&gt;
13&amp;gt;                   CHAR((CONVERT(int, RAND() * 1000) % 26 ) + 65)&lt;br /&gt;
14&amp;gt;                  -- 65 is &amp;quot;A&amp;quot;&lt;br /&gt;
15&amp;gt;                  + CHAR((CONVERT(int, RAND() * 1000) % 26 ) + 65)&lt;br /&gt;
16&amp;gt;                  + CHAR((CONVERT(int, RAND() * 1000) % 26 ) + 65)&lt;br /&gt;
17&amp;gt;                  + CHAR((CONVERT(int, RAND() * 1000) % 26 ) + 65)&lt;br /&gt;
18&amp;gt;                  + REPLICATE(CHAR((CONVERT(int, RAND() * 1000)&lt;br /&gt;
19&amp;gt;                      % 26) + 65), 11)&lt;br /&gt;
20&amp;gt; )&lt;br /&gt;
21&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; DECLARE @counter int&lt;br /&gt;
3&amp;gt; SET @counter=1&lt;br /&gt;
4&amp;gt; WHILE (@counter &amp;lt;= 1000)&lt;br /&gt;
5&amp;gt;     BEGIN&lt;br /&gt;
6&amp;gt;     INSERT random_data DEFAULT VALUES&lt;br /&gt;
7&amp;gt;     SET @counter=@counter + 1&lt;br /&gt;
8&amp;gt;     END&lt;br /&gt;
9&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table random_data;&lt;br /&gt;
3&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== DEFAULT 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;
5&amp;gt;    CREATE TABLE Shippers&lt;br /&gt;
6&amp;gt;    (&lt;br /&gt;
7&amp;gt;       ShipperID      int   IDENTITY   NOT NULL&lt;br /&gt;
8&amp;gt;          PRIMARY KEY,&lt;br /&gt;
9&amp;gt;       ShipperName    varchar(30)      NOT NULL,&lt;br /&gt;
10&amp;gt;       DateInSystem   smalldatetime    NOT NULL&lt;br /&gt;
11&amp;gt;          DEFAULT GETDATE ()&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;    CREATE TABLE Customers&lt;br /&gt;
3&amp;gt;    (&lt;br /&gt;
4&amp;gt;       CustomerNo     int     IDENTITY   NOT NULL&lt;br /&gt;
5&amp;gt;          PRIMARY KEY,&lt;br /&gt;
6&amp;gt;       CustomerName   varchar(30)        NOT NULL,&lt;br /&gt;
7&amp;gt;       Address1       varchar(30)        NOT NULL,&lt;br /&gt;
8&amp;gt;       Address2       varchar(30)        NOT NULL,&lt;br /&gt;
9&amp;gt;      City            varchar(20)        NOT NULL,&lt;br /&gt;
10&amp;gt;      State           char(2)            NOT NULL,&lt;br /&gt;
11&amp;gt;      Zip             varchar(10)        NOT NULL,&lt;br /&gt;
12&amp;gt;      Contact         varchar(25)        NOT NULL,&lt;br /&gt;
13&amp;gt;      Phone           char(15)           NOT NULL,&lt;br /&gt;
14&amp;gt;      FedIDNo         varchar(9)         NOT NULL,&lt;br /&gt;
15&amp;gt;      DateInSystem    smalldatetime      NOT 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;    ALTER TABLE Customers&lt;br /&gt;
3&amp;gt;       ADD CONSTRAINT CN_CustomerDefaultDateInSystem&lt;br /&gt;
4&amp;gt;          DEFAULT GETDATE() FOR DateInSystem&lt;br /&gt;
5&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table Shippers;&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;
== Default int type value and default char type 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;
2&amp;gt; CREATE TABLE xyz&lt;br /&gt;
3&amp;gt; (&lt;br /&gt;
4&amp;gt; col1    int            PRIMARY KEY IDENTITY(1, 1) NOT NULL,&lt;br /&gt;
5&amp;gt; col2    int            NOT NULL DEFAULT 999,&lt;br /&gt;
6&amp;gt; col3    char(10)       NOT NULL DEFAULT &amp;quot;ABCEFGHIJK&amp;quot;&lt;br /&gt;
7&amp;gt; )&lt;br /&gt;
8&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; SET NOCOUNT ON&lt;br /&gt;
3&amp;gt; DECLARE @counter int&lt;br /&gt;
4&amp;gt; SET @counter=1&lt;br /&gt;
5&amp;gt; WHILE (@counter &amp;lt;= 1000)&lt;br /&gt;
6&amp;gt;     BEGIN&lt;br /&gt;
7&amp;gt;     INSERT xyz DEFAULT VALUES&lt;br /&gt;
8&amp;gt;     SET @counter=@counter+1&lt;br /&gt;
9&amp;gt;     END&lt;br /&gt;
10&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; drop table xyz;&lt;br /&gt;
4&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Designating Default Column Values: Assign Zeroes Instead of Null Values==&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; CREATE TABLE T (&lt;br /&gt;
7&amp;gt;     int1 int,&lt;br /&gt;
8&amp;gt;     bit1 bit NOT NULL DEFAULT 0,&lt;br /&gt;
9&amp;gt;     varchar1 varchar(3),&lt;br /&gt;
10&amp;gt;     dec1 dec(5,2),&lt;br /&gt;
11&amp;gt;     cmp1 AS (int1 + bit1)&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; drop table t;&lt;br /&gt;
3&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Dropping Defaults==&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;
DROP DEFAULT &amp;lt;default name&amp;gt;&lt;br /&gt;
EXEC sp_depends &amp;lt;object name&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Insert to a table with default 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;
2&amp;gt; CREATE TABLE T (&lt;br /&gt;
3&amp;gt;     int1 int,&lt;br /&gt;
4&amp;gt;     bit1 bit NOT NULL DEFAULT 0,&lt;br /&gt;
5&amp;gt;     rvr1 timestamp,&lt;br /&gt;
6&amp;gt;     usr1 nvarchar(128) DEFAULT USER,&lt;br /&gt;
7&amp;gt;     createtime datetime DEFAULT CURRENT_TIMESTAMP&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; INSERT T (int1, bit1) VALUES (3, 1)&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; drop table t;&lt;br /&gt;
3&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== The syntax for defining a default==&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 DEFAULT &amp;lt;default name&amp;gt;&lt;br /&gt;
AS &amp;lt;default value&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Using the system date as a default parameter.==&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;&lt;br /&gt;
7&amp;gt;     CREATE TABLE myusers(&lt;br /&gt;
8&amp;gt;         UserID        varchar(30)NOT NULL PRIMARY KEY,&lt;br /&gt;
9&amp;gt;         FirstName     varchar(30),&lt;br /&gt;
10&amp;gt;         LastName      varchar(30),&lt;br /&gt;
11&amp;gt;         EmployeeType  char(1) NOT NULL,&lt;br /&gt;
12&amp;gt;         DBAccess      varchar(30),&lt;br /&gt;
13&amp;gt;         StartDate     datetime,&lt;br /&gt;
14&amp;gt;         ExpDate       datetime&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;&lt;br /&gt;
3&amp;gt;     CREATE PROC pr_deluser (@TD datetime )&lt;br /&gt;
4&amp;gt;     AS&lt;br /&gt;
5&amp;gt;     DECLARE getuser_curs CURSOR&lt;br /&gt;
6&amp;gt;          FOR&lt;br /&gt;
7&amp;gt;               SELECT UserID&lt;br /&gt;
8&amp;gt;               FROM myusers&lt;br /&gt;
9&amp;gt;               WHERE ExpDate &amp;lt;= @TD&lt;br /&gt;
10&amp;gt;     DECLARE @HoldID varchar(30)&lt;br /&gt;
11&amp;gt;     DECLARE @MyCount int&lt;br /&gt;
12&amp;gt;     SELECT @MyCount = 0&lt;br /&gt;
13&amp;gt;     OPEN getuser_curs&lt;br /&gt;
14&amp;gt;     FETCH NEXT FROM getuser_curs into @HoldID&lt;br /&gt;
15&amp;gt;     WHILE @@FETCH_STATUS = 0 BEGIN&lt;br /&gt;
16&amp;gt;          EXEC sp_droplogin @HoldID&lt;br /&gt;
17&amp;gt;          EXEC pr_copyuser @HoldID&lt;br /&gt;
18&amp;gt;          SELECT @MyCount = @MyCount + 1&lt;br /&gt;
19&amp;gt;          FETCH NEXT FROM getuser_curs into @HoldID&lt;br /&gt;
20&amp;gt;     END&lt;br /&gt;
21&amp;gt;     DECLARE @MyDisp varchar(50)&lt;br /&gt;
22&amp;gt;     SELECT @MyDisp = &amp;quot;Number of Users Deleted is &amp;quot; + ltrim(str(@MyCount))&lt;br /&gt;
23&amp;gt;     PRINT @MyDisp&lt;br /&gt;
24&amp;gt;     CLOSE getuser_curs&lt;br /&gt;
25&amp;gt;     DEALLOCATE getuser_curs&lt;br /&gt;
26&amp;gt;     GO&lt;br /&gt;
Cannot add rows to sysdepends for the current object because it depends on the missing object &amp;quot;pr_copyuser&amp;quot;. The object will still be created.&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;     DECLARE @myvalue varchar(12)&lt;br /&gt;
4&amp;gt;&lt;br /&gt;
5&amp;gt;     SELECT @myvalue=CONVERT(varchar(12), getdate())&lt;br /&gt;
6&amp;gt;&lt;br /&gt;
7&amp;gt;     EXEC pr_deluser @myvalue&lt;br /&gt;
8&amp;gt;     GO&lt;br /&gt;
Number of Users Deleted is 0&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;     drop PROC pr_deluser;&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 myusers;&lt;br /&gt;
4&amp;gt;     GO&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>