<?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%2FStore_Procedure_Function%2FDefault_Parameter</id>
		<title>SQL Server/T-SQL/Store Procedure Function/Default Parameter - История изменений</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%2FStore_Procedure_Function%2FDefault_Parameter"/>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=SQL_Server/T-SQL/Store_Procedure_Function/Default_Parameter&amp;action=history"/>
		<updated>2026-04-06T03:33:15Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://sqle.ru/index.php?title=SQL_Server/T-SQL/Store_Procedure_Function/Default_Parameter&amp;diff=6180&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/Store_Procedure_Function/Default_Parameter&amp;diff=6180&amp;oldid=prev"/>
				<updated>2010-05-26T13:46:06Z</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/Store_Procedure_Function/Default_Parameter&amp;diff=6181&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/Store_Procedure_Function/Default_Parameter&amp;diff=6181&amp;oldid=prev"/>
				<updated>2010-05-26T10:21:28Z</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;==Paraemter with 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;
&lt;br /&gt;
1&amp;gt; create table employee(&lt;br /&gt;
2&amp;gt;     ID          int,&lt;br /&gt;
3&amp;gt;     name        nvarchar (10),&lt;br /&gt;
4&amp;gt;     salary      int,&lt;br /&gt;
5&amp;gt;     start_date  datetime,&lt;br /&gt;
6&amp;gt;     city        nvarchar (10),&lt;br /&gt;
7&amp;gt;     region      char (1))&lt;br /&gt;
8&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
3&amp;gt;               values (1,  &amp;quot;Jason&amp;quot;, 40420,  &amp;quot;02/01/94&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;W&amp;quot;)&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (2,  &amp;quot;Robert&amp;quot;,14420,  &amp;quot;01/02/95&amp;quot;, &amp;quot;Vancouver&amp;quot;,&amp;quot;N&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (3,  &amp;quot;Celia&amp;quot;, 24020,  &amp;quot;12/03/96&amp;quot;, &amp;quot;Toronto&amp;quot;,  &amp;quot;W&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (4,  &amp;quot;Linda&amp;quot;, 40620,  &amp;quot;11/04/97&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;N&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (5,  &amp;quot;David&amp;quot;, 80026,  &amp;quot;10/05/98&amp;quot;, &amp;quot;Vancouver&amp;quot;,&amp;quot;W&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (6,  &amp;quot;James&amp;quot;, 70060,  &amp;quot;09/06/99&amp;quot;, &amp;quot;Toronto&amp;quot;,  &amp;quot;N&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (7,  &amp;quot;Alison&amp;quot;,90620,  &amp;quot;08/07/00&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;W&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (8,  &amp;quot;Chris&amp;quot;, 26020,  &amp;quot;07/08/01&amp;quot;, &amp;quot;Vancouver&amp;quot;,&amp;quot;N&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (9,  &amp;quot;Mary&amp;quot;,  60020,  &amp;quot;06/09/02&amp;quot;, &amp;quot;Toronto&amp;quot;,  &amp;quot;W&amp;quot;)&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; select * from employee&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
ID          name       salary      start_date              city       region&lt;br /&gt;
----------- ---------- ----------- ----------------------- ---------- ------&lt;br /&gt;
          1 Jason            40420 1994-02-01 00:00:00.000 New York   W&lt;br /&gt;
          2 Robert           14420 1995-01-02 00:00:00.000 Vancouver  N&lt;br /&gt;
          3 Celia            24020 1996-12-03 00:00:00.000 Toronto    W&lt;br /&gt;
          4 Linda            40620 1997-11-04 00:00:00.000 New York   N&lt;br /&gt;
          5 David            80026 1998-10-05 00:00:00.000 Vancouver  W&lt;br /&gt;
          6 James            70060 1999-09-06 00:00:00.000 Toronto    N&lt;br /&gt;
          7 Alison           90620 2000-08-07 00:00:00.000 New York   W&lt;br /&gt;
          8 Chris            26020 2001-07-08 00:00:00.000 Vancouver  N&lt;br /&gt;
          9 Mary             60020 2002-06-09 00:00:00.000 Toronto    W&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop PROCEDURE GetData&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; -- Filtering for Null Values with a Stored Procedure&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt; CREATE PROCEDURE GetData&lt;br /&gt;
5&amp;gt; @TID int = NULL&lt;br /&gt;
6&amp;gt; AS&lt;br /&gt;
7&amp;gt; IF @TID IS NOT NULL&lt;br /&gt;
8&amp;gt;     SELECT ID, name FROM Employee WHERE ID = @TID&lt;br /&gt;
9&amp;gt; ELSE&lt;br /&gt;
10&amp;gt;     SELECT id, Name FROM Employee WHERE ID IS NULL&lt;br /&gt;
11&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; EXEC GetData 1&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
ID          name&lt;br /&gt;
----------- ----------&lt;br /&gt;
          1 Jason&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; EXEC GetData NULL&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
id          Name&lt;br /&gt;
----------- ----------&lt;br /&gt;
(0 rows affected)&lt;br /&gt;
1&amp;gt; EXEC GetData&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
id          Name&lt;br /&gt;
----------- ----------&lt;br /&gt;
(0 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table employee&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Specifying a Default Parameter 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;
&lt;br /&gt;
1&amp;gt; create table employee(&lt;br /&gt;
2&amp;gt;     ID          int,&lt;br /&gt;
3&amp;gt;     name        nvarchar (10),&lt;br /&gt;
4&amp;gt;     salary      int,&lt;br /&gt;
5&amp;gt;     start_date  datetime,&lt;br /&gt;
6&amp;gt;     city        nvarchar (10),&lt;br /&gt;
7&amp;gt;     region      char (1))&lt;br /&gt;
8&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
3&amp;gt;               values (1,  &amp;quot;Jason&amp;quot;, 40420,  &amp;quot;02/01/94&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;W&amp;quot;)&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (2,  &amp;quot;Robert&amp;quot;,14420,  &amp;quot;01/02/95&amp;quot;, &amp;quot;Vancouver&amp;quot;,&amp;quot;N&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (3,  &amp;quot;Celia&amp;quot;, 24020,  &amp;quot;12/03/96&amp;quot;, &amp;quot;Toronto&amp;quot;,  &amp;quot;W&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (4,  &amp;quot;Linda&amp;quot;, 40620,  &amp;quot;11/04/97&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;N&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (5,  &amp;quot;David&amp;quot;, 80026,  &amp;quot;10/05/98&amp;quot;, &amp;quot;Vancouver&amp;quot;,&amp;quot;W&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (6,  &amp;quot;James&amp;quot;, 70060,  &amp;quot;09/06/99&amp;quot;, &amp;quot;Toronto&amp;quot;,  &amp;quot;N&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (7,  &amp;quot;Alison&amp;quot;,90620,  &amp;quot;08/07/00&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;W&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (8,  &amp;quot;Chris&amp;quot;, 26020,  &amp;quot;07/08/01&amp;quot;, &amp;quot;Vancouver&amp;quot;,&amp;quot;N&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (9,  &amp;quot;Mary&amp;quot;,  60020,  &amp;quot;06/09/02&amp;quot;, &amp;quot;Toronto&amp;quot;,  &amp;quot;W&amp;quot;)&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; select * from employee&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
ID          name       salary      start_date              city       region&lt;br /&gt;
----------- ---------- ----------- ----------------------- ---------- ------&lt;br /&gt;
          1 Jason            40420 1994-02-01 00:00:00.000 New York   W&lt;br /&gt;
          2 Robert           14420 1995-01-02 00:00:00.000 Vancouver  N&lt;br /&gt;
          3 Celia            24020 1996-12-03 00:00:00.000 Toronto    W&lt;br /&gt;
          4 Linda            40620 1997-11-04 00:00:00.000 New York   N&lt;br /&gt;
          5 David            80026 1998-10-05 00:00:00.000 Vancouver  W&lt;br /&gt;
          6 James            70060 1999-09-06 00:00:00.000 Toronto    N&lt;br /&gt;
          7 Alison           90620 2000-08-07 00:00:00.000 New York   W&lt;br /&gt;
          8 Chris            26020 2001-07-08 00:00:00.000 Vancouver  N&lt;br /&gt;
          9 Mary             60020 2002-06-09 00:00:00.000 Toronto    W&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop PROCEDURE GetData&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; -- Specifying a Default Parameter Value&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt; CREATE PROCEDURE GetData @TID int = 3&lt;br /&gt;
5&amp;gt; AS&lt;br /&gt;
6&amp;gt; SELECT * from Employee WHERE ID = @TID&lt;br /&gt;
7&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; EXEC GetData 1&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
ID          name       salary      start_date              city       region&lt;br /&gt;
----------- ---------- ----------- ----------------------- ---------- ------&lt;br /&gt;
          1 Jason            40420 1994-02-01 00:00:00.000 New York   W&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; EXEC GetData&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
ID          name       salary      start_date              city       region&lt;br /&gt;
----------- ---------- ----------- ----------------------- ---------- ------&lt;br /&gt;
          3 Celia            24020 1996-12-03 00:00:00.000 Toronto    W&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table employee&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&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;
 &lt;br /&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&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>