<?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%2FTransact_SQL%2FWith</id>
		<title>SQL Server/T-SQL Tutorial/Transact SQL/With - История изменений</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%2FTransact_SQL%2FWith"/>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Transact_SQL/With&amp;action=history"/>
		<updated>2026-04-04T13:47:11Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Transact_SQL/With&amp;diff=6352&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/Transact_SQL/With&amp;diff=6352&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/Transact_SQL/With&amp;diff=6353&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/Transact_SQL/With&amp;diff=6353&amp;oldid=prev"/>
				<updated>2010-05-26T10:22:44Z</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;== Common Table Expressions==&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;
A Common Table Expression (CTE) creates a temporary query that can be referenced within the scope of a SELECT, INSERT, UPDATE, or DELETE query.&lt;br /&gt;
The basic syntax for a CTE is as follows:&lt;br /&gt;
WITH expression_name [ ( column_name [ ,...n ] ) ]&lt;br /&gt;
AS ( CTE_query_definition )&lt;br /&gt;
The arguments of a CTE are described in the following table.&lt;br /&gt;
Argument                   Description&lt;br /&gt;
expression_name            The name of the common table expression.&lt;br /&gt;
column_name [ ,...n ]      The unique column names of the expression.&lt;br /&gt;
CTE_query_definition       The SELECT query that defines the common table expression.&lt;br /&gt;
A non-recursive CTE is one that is used within a query without referencing itself. &lt;br /&gt;
It serves as a temporary result set for the query. &lt;br /&gt;
A recursive CTE is defined similarly to a non-recursive CTE, only a recursive CTE returns hierarchical self-relating data. &lt;br /&gt;
Using a CTE to represent recursive data can minimize the amount of code needed compared to other methods.&lt;br /&gt;
Referenced from:&lt;br /&gt;
SQL Server 2005 T-SQL Recipes A Problem-Solution Approach&lt;br /&gt;
&lt;br /&gt;
5&amp;gt; create table freights&lt;br /&gt;
6&amp;gt;        (orderid INT NOT NULL,&lt;br /&gt;
7&amp;gt;        orderdate DATETIME,&lt;br /&gt;
8&amp;gt;        shippeddate DATETIME,&lt;br /&gt;
9&amp;gt;        freight MONEY,&lt;br /&gt;
10&amp;gt;        price MONEY)&lt;br /&gt;
11&amp;gt; GO&lt;br /&gt;
1&amp;gt; INSERT INTO freights VALUES (1111, &amp;quot;1.10.2005&amp;quot;,&amp;quot;1.20.2005&amp;quot;, 30.45, 200.25)&lt;br /&gt;
2&amp;gt; INSERT INTO freights VALUES (2222, &amp;quot;2.11.2005&amp;quot;, &amp;quot;2.21.2005&amp;quot;, 89.25, 543.00)&lt;br /&gt;
3&amp;gt; INSERT INTO freights VALUES (3333, &amp;quot;3.12.2005&amp;quot;, &amp;quot;3.22.2005&amp;quot;, 19.35, 120.25)&lt;br /&gt;
4&amp;gt; INSERT INTO freights VALUES (4444, &amp;quot;4.13.2005&amp;quot;, &amp;quot;4.23.2005&amp;quot;, 9.99, 154.35)&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; select orderid from freights&lt;br /&gt;
2&amp;gt; where price &amp;gt; (SELECT AVG(price) from freights WHERE YEAR(orderdate) = &amp;quot;2005&amp;quot;)&lt;br /&gt;
3&amp;gt;         AND freight &amp;gt; (SELECT AVG(price)&lt;br /&gt;
4&amp;gt;                     from freights&lt;br /&gt;
5&amp;gt;                     WHERE YEAR(orderdate) = &amp;quot;2005&amp;quot;)/10&lt;br /&gt;
6&amp;gt; GO&lt;br /&gt;
orderid&lt;br /&gt;
-----------&lt;br /&gt;
       2222&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; --A better way is to write a common table expression using the WITH clause.&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; WITH price_calc (year_2005) AS&lt;br /&gt;
4&amp;gt;        (SELECT AVG(price)&lt;br /&gt;
5&amp;gt;                 from freights&lt;br /&gt;
6&amp;gt;                 WHERE YEAR(orderdate)=&amp;quot;2005&amp;quot;)&lt;br /&gt;
7&amp;gt;       SELECT orderid&lt;br /&gt;
8&amp;gt;        FROM freights&lt;br /&gt;
9&amp;gt;        WHERE price &amp;gt; (SELECT year_2005&lt;br /&gt;
10&amp;gt;              FROM price_calc)&lt;br /&gt;
11&amp;gt;        AND freight &amp;gt; (SELECT year_2005&lt;br /&gt;
12&amp;gt;              FROM price_calc)/10;&lt;br /&gt;
13&amp;gt; drop table freights;&lt;br /&gt;
14&amp;gt; GO&lt;br /&gt;
orderid&lt;br /&gt;
-----------&lt;br /&gt;
       2222&lt;br /&gt;
(1 rows affected)&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Select from Common Table Expressions==&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;
91&amp;gt;&lt;br /&gt;
92&amp;gt; CREATE TABLE employee(&lt;br /&gt;
93&amp;gt;    id          INTEGER NOT NULL PRIMARY KEY,&lt;br /&gt;
94&amp;gt;    first_name  VARCHAR(10),&lt;br /&gt;
95&amp;gt;    last_name   VARCHAR(10),&lt;br /&gt;
96&amp;gt;    salary      DECIMAL(10,2),&lt;br /&gt;
97&amp;gt;    start_Date  DATETIME,&lt;br /&gt;
98&amp;gt;    region      VARCHAR(10),&lt;br /&gt;
99&amp;gt;    city        VARCHAR(20),&lt;br /&gt;
100&amp;gt;    managerid   INTEGER&lt;br /&gt;
101&amp;gt; );&lt;br /&gt;
102&amp;gt; GO&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (1, &amp;quot;Jason&amp;quot; ,  &amp;quot;Martin&amp;quot;, 5890,&amp;quot;2005-03-22&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Vancouver&amp;quot;,3);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (2, &amp;quot;Alison&amp;quot;,  &amp;quot;Mathews&amp;quot;,4789,&amp;quot;2003-07-21&amp;quot;,&amp;quot;South&amp;quot;,&amp;quot;Utown&amp;quot;,4);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (3, &amp;quot;James&amp;quot; ,  &amp;quot;Smith&amp;quot;,  6678,&amp;quot;2001-12-01&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Paris&amp;quot;,5);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (4, &amp;quot;Celia&amp;quot; ,  &amp;quot;Rice&amp;quot;,   5567,&amp;quot;2006-03-03&amp;quot;,&amp;quot;South&amp;quot;,&amp;quot;London&amp;quot;,6);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (5, &amp;quot;Robert&amp;quot;,  &amp;quot;Black&amp;quot;,  4467,&amp;quot;2004-07-02&amp;quot;,&amp;quot;East&amp;quot;,&amp;quot;Newton&amp;quot;,7);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (6, &amp;quot;Linda&amp;quot; ,  &amp;quot;Green&amp;quot; , 6456,&amp;quot;2002-05-19&amp;quot;,&amp;quot;East&amp;quot;,&amp;quot;Calgary&amp;quot;,8);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (7, &amp;quot;David&amp;quot; ,  &amp;quot;Larry&amp;quot;,  5345,&amp;quot;2008-03-18&amp;quot;,&amp;quot;West&amp;quot;,&amp;quot;New York&amp;quot;,9);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (8, &amp;quot;James&amp;quot; ,  &amp;quot;Cat&amp;quot;,    4234,&amp;quot;2007-07-17&amp;quot;,&amp;quot;West&amp;quot;,&amp;quot;Regina&amp;quot;,9);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (9, &amp;quot;Joan&amp;quot;  ,  &amp;quot;Act&amp;quot;,    6123,&amp;quot;2001-04-16&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Toronto&amp;quot;,10);&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; select * from employee;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
id          first_name last_name  salary       start_Date              region     city                 managerid&lt;br /&gt;
----------- ---------- ---------- ------------ ----------------------- ---------- -------------------- -----------&lt;br /&gt;
          1 Jason      Martin          5890.00 2005-03-22 00:00:00.000 North      Vancouver                      3&lt;br /&gt;
          2 Alison     Mathews         4789.00 2003-07-21 00:00:00.000 South      Utown                          4&lt;br /&gt;
          3 James      Smith           6678.00 2001-12-01 00:00:00.000 North      Paris                          5&lt;br /&gt;
          4 Celia      Rice            5567.00 2006-03-03 00:00:00.000 South      London                         6&lt;br /&gt;
          5 Robert     Black           4467.00 2004-07-02 00:00:00.000 East       Newton                         7&lt;br /&gt;
          6 Linda      Green           6456.00 2002-05-19 00:00:00.000 East       Calgary                        8&lt;br /&gt;
          7 David      Larry           5345.00 2008-03-18 00:00:00.000 West       New York                       9&lt;br /&gt;
          8 James      Cat             4234.00 2007-07-17 00:00:00.000 West       Regina                         9&lt;br /&gt;
          9 Joan       Act             6123.00 2001-04-16 00:00:00.000 North      Toronto                       10&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; WITH MySearch (ID, first_Name)&lt;br /&gt;
4&amp;gt; AS&lt;br /&gt;
5&amp;gt; (&lt;br /&gt;
6&amp;gt; SELECT ID,first_Name&lt;br /&gt;
7&amp;gt; FROM employee&lt;br /&gt;
8&amp;gt; )&lt;br /&gt;
9&amp;gt;&lt;br /&gt;
10&amp;gt; SELECT v.first_Name&lt;br /&gt;
11&amp;gt; FROM MySearch v&lt;br /&gt;
12&amp;gt; GO&lt;br /&gt;
first_Name&lt;br /&gt;
----------&lt;br /&gt;
Jason&lt;br /&gt;
Alison&lt;br /&gt;
James&lt;br /&gt;
Celia&lt;br /&gt;
Robert&lt;br /&gt;
Linda&lt;br /&gt;
David&lt;br /&gt;
James&lt;br /&gt;
Joan&lt;br /&gt;
(9 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; drop table employee;&lt;br /&gt;
6&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Syntax for a CTE for recursive queries is==&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 airplane&lt;br /&gt;
7&amp;gt;        (containing_assembly VARCHAR(10),&lt;br /&gt;
8&amp;gt;        contained_assembly VARCHAR(10),&lt;br /&gt;
9&amp;gt;        quantity_contained INT,&lt;br /&gt;
10&amp;gt;        unit_cost DECIMAL (6,2))&lt;br /&gt;
11&amp;gt; GO&lt;br /&gt;
1&amp;gt;       insert into airplane values (&amp;quot;Airplane&amp;quot;, &amp;quot;Fuselage&amp;quot;, 1, 10)&lt;br /&gt;
2&amp;gt;       insert into airplane values (&amp;quot;Airplane&amp;quot;, &amp;quot;Wings&amp;quot;, 1, 11)&lt;br /&gt;
3&amp;gt;       insert into airplane values (&amp;quot;Airplane&amp;quot;, &amp;quot;Tail&amp;quot;, 1, 12)&lt;br /&gt;
4&amp;gt;       insert into airplane values (&amp;quot;Fuselage&amp;quot;, &amp;quot;Cockpit&amp;quot;, 1, 13)&lt;br /&gt;
5&amp;gt;       insert into airplane values (&amp;quot;Fuselage&amp;quot;, &amp;quot;Cabin&amp;quot;, 1, 14)&lt;br /&gt;
6&amp;gt;       insert into airplane values (&amp;quot;Fuselage&amp;quot;, &amp;quot;Nose&amp;quot;, 1, 15)&lt;br /&gt;
7&amp;gt;       insert into airplane values (&amp;quot;Cockpit&amp;quot;, NULL, 1, 13)&lt;br /&gt;
8&amp;gt;       insert into airplane values (&amp;quot;Cabin&amp;quot;, NULL, 1, 14)&lt;br /&gt;
9&amp;gt;       insert into airplane values (&amp;quot;Nose&amp;quot;, NULL, 1, 15)&lt;br /&gt;
10&amp;gt;       insert into airplane values (&amp;quot;Wings&amp;quot;, NULL, 2, 11)&lt;br /&gt;
11&amp;gt;       insert into airplane values (&amp;quot;Tail&amp;quot;, NULL, 1, 12)&lt;br /&gt;
12&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 rows affected)&lt;br /&gt;
1&amp;gt; --The following example shows the use of the WITH clause to define a query that calculates the total costs of each assembly.&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;       WITH list_of_parts(assembly, quantity, cost) AS&lt;br /&gt;
4&amp;gt;       (SELECT containing_assembly, quantity_contained, unit_cost&lt;br /&gt;
5&amp;gt;         FROM airplane&lt;br /&gt;
6&amp;gt;         WHERE contained_assembly IS NULL&lt;br /&gt;
7&amp;gt;       UNION ALL&lt;br /&gt;
8&amp;gt;       SELECT a.containing_assembly, a.quantity_contained,&lt;br /&gt;
9&amp;gt;          CAST(l.quantity*l.cost AS DECIMAL(6,2))&lt;br /&gt;
10&amp;gt;          FROM list_of_parts l,airplane a&lt;br /&gt;
11&amp;gt;          WHERE l.assembly = a.contained_assembly)&lt;br /&gt;
12&amp;gt;       SELECT * FROM list_of_parts&lt;br /&gt;
13&amp;gt; GO&lt;br /&gt;
assembly   quantity    cost&lt;br /&gt;
---------- ----------- --------&lt;br /&gt;
Cockpit              1    13.00&lt;br /&gt;
Cabin                1    14.00&lt;br /&gt;
Nose                 1    15.00&lt;br /&gt;
Wings                2    11.00&lt;br /&gt;
Tail                 1    12.00&lt;br /&gt;
Cockpit              1    13.00&lt;br /&gt;
Cabin                1    14.00&lt;br /&gt;
Nose                 1    15.00&lt;br /&gt;
Wings                2    11.00&lt;br /&gt;
Tail                 1    12.00&lt;br /&gt;
Cockpit              1    13.00&lt;br /&gt;
Cabin                1    14.00&lt;br /&gt;
Nose                 1    15.00&lt;br /&gt;
Wings                2    11.00&lt;br /&gt;
Tail                 1    12.00&lt;br /&gt;
Airplane             1    12.00&lt;br /&gt;
Airplane             1    12.00&lt;br /&gt;
Airplane             1    12.00&lt;br /&gt;
Airplane             1    22.00&lt;br /&gt;
Airplane             1    22.00&lt;br /&gt;
Airplane             1    22.00&lt;br /&gt;
Fuselage             1    15.00&lt;br /&gt;
Fuselage             1    15.00&lt;br /&gt;
Fuselage             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Fuselage             1    14.00&lt;br /&gt;
Fuselage             1    14.00&lt;br /&gt;
Fuselage             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Fuselage             1    13.00&lt;br /&gt;
Fuselage             1    13.00&lt;br /&gt;
Fuselage             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    12.00&lt;br /&gt;
Airplane             1    12.00&lt;br /&gt;
Airplane             1    12.00&lt;br /&gt;
Airplane             1    22.00&lt;br /&gt;
Airplane             1    22.00&lt;br /&gt;
Airplane             1    22.00&lt;br /&gt;
Fuselage             1    15.00&lt;br /&gt;
Fuselage             1    15.00&lt;br /&gt;
Fuselage             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Fuselage             1    14.00&lt;br /&gt;
Fuselage             1    14.00&lt;br /&gt;
Fuselage             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Fuselage             1    13.00&lt;br /&gt;
Fuselage             1    13.00&lt;br /&gt;
Fuselage             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    12.00&lt;br /&gt;
Airplane             1    12.00&lt;br /&gt;
Airplane             1    12.00&lt;br /&gt;
Airplane             1    22.00&lt;br /&gt;
Airplane             1    22.00&lt;br /&gt;
Airplane             1    22.00&lt;br /&gt;
Fuselage             1    15.00&lt;br /&gt;
Fuselage             1    15.00&lt;br /&gt;
Fuselage             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Airplane             1    15.00&lt;br /&gt;
Fuselage             1    14.00&lt;br /&gt;
Fuselage             1    14.00&lt;br /&gt;
Fuselage             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Airplane             1    14.00&lt;br /&gt;
Fuselage             1    13.00&lt;br /&gt;
Fuselage             1    13.00&lt;br /&gt;
Fuselage             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
Airplane             1    13.00&lt;br /&gt;
(141 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table airplane;&lt;br /&gt;
3&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;
== With as==&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;
20&amp;gt; CREATE TABLE Employees (&lt;br /&gt;
21&amp;gt;     EmployeeID int IDENTITY (1, 1) NOT NULL ,&lt;br /&gt;
22&amp;gt;     LastName nvarchar (20) NOT NULL ,&lt;br /&gt;
23&amp;gt;     FirstName nvarchar (10) NOT NULL ,&lt;br /&gt;
24&amp;gt;     Title nvarchar (30) NULL ,&lt;br /&gt;
25&amp;gt;     TitleOfCourtesy nvarchar (25) NULL ,&lt;br /&gt;
26&amp;gt;     BirthDate datetime NULL ,&lt;br /&gt;
27&amp;gt;     HireDate datetime NULL ,&lt;br /&gt;
28&amp;gt;     Address nvarchar (60) NULL ,&lt;br /&gt;
29&amp;gt;     City nvarchar (15) NULL ,&lt;br /&gt;
30&amp;gt;     Region nvarchar (15) NULL ,&lt;br /&gt;
31&amp;gt;     PostalCode nvarchar (10) NULL ,&lt;br /&gt;
32&amp;gt;     Country nvarchar (15) NULL ,&lt;br /&gt;
33&amp;gt;     HomePhone nvarchar (24) NULL ,&lt;br /&gt;
34&amp;gt;     Extension nvarchar (4) NULL ,&lt;br /&gt;
35&amp;gt;     Photo image NULL ,&lt;br /&gt;
36&amp;gt;     Notes ntext NULL ,&lt;br /&gt;
37&amp;gt;     ReportsTo int NULL ,&lt;br /&gt;
38&amp;gt;     PhotoPath nvarchar (255) NULL&lt;br /&gt;
39&amp;gt;&lt;br /&gt;
40&amp;gt; )&lt;br /&gt;
41&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt; WITH Args1 AS&lt;br /&gt;
5&amp;gt; (&lt;br /&gt;
6&amp;gt;   SELECT LastName, FirstName, BirthDate,&lt;br /&gt;
7&amp;gt;     DATEDIFF(year, BirthDate, GETDATE()) AS Diff,&lt;br /&gt;
8&amp;gt;     CAST(CONVERT(CHAR(8), GETDATE(), 112) AS DATETIME) AS Today&lt;br /&gt;
9&amp;gt;   FROM dbo.Employees&lt;br /&gt;
10&amp;gt; ),&lt;br /&gt;
11&amp;gt;&lt;br /&gt;
12&amp;gt; Args2 AS&lt;br /&gt;
13&amp;gt; (&lt;br /&gt;
14&amp;gt;   SELECT LastName, FirstName, BirthDate, Today,&lt;br /&gt;
15&amp;gt;     DATEADD(year, Diff, BirthDate) AS BDCur,&lt;br /&gt;
16&amp;gt;     DATEADD(year, Diff + 1, BirthDate) AS BDNxt&lt;br /&gt;
17&amp;gt;   FROM Args1&lt;br /&gt;
18&amp;gt; ),&lt;br /&gt;
19&amp;gt; Args3 AS&lt;br /&gt;
20&amp;gt; (&lt;br /&gt;
21&amp;gt;   SELECT LastName, FirstName, BirthDate, Today,&lt;br /&gt;
22&amp;gt;     BDCur + CASE WHEN DAY(BirthDate) = 29 AND DAY(BDCur) = 28&lt;br /&gt;
23&amp;gt;       THEN 1 ELSE 0 END AS BDCur,&lt;br /&gt;
24&amp;gt;     BDNxt + CASE WHEN DAY(BirthDate) = 29 AND DAY(BDNxt) = 28&lt;br /&gt;
25&amp;gt;       THEN 1 ELSE 0 END AS BDNxt&lt;br /&gt;
26&amp;gt;   FROM Args2&lt;br /&gt;
27&amp;gt; )&lt;br /&gt;
28&amp;gt;&lt;br /&gt;
29&amp;gt; SELECT LastName, FirstName, BirthDate,&lt;br /&gt;
30&amp;gt;   CASE WHEN BDCur &amp;gt;= Today THEN BDCur ELSE BDNxt END AS BirthDay&lt;br /&gt;
31&amp;gt; FROM Args3;&lt;br /&gt;
32&amp;gt;&lt;br /&gt;
33&amp;gt; drop table Employees;&lt;br /&gt;
34&amp;gt; GO&lt;br /&gt;
LastName             FirstName  BirthDate               BirthDay&lt;br /&gt;
-------------------- ---------- ----------------------- -----------------------&lt;br /&gt;
Today                Mary       2008-08-17 00:00:00.000 2008-08-17 00:00:00.000&lt;br /&gt;
1&amp;gt;&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>