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

	<entry>
		<id>http://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Subquery/Correlated_subquery&amp;diff=7159&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/Subquery/Correlated_subquery&amp;diff=7159&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/Subquery/Correlated_subquery&amp;diff=7160&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/Subquery/Correlated_subquery&amp;diff=7160&amp;oldid=prev"/>
				<updated>2010-05-26T10:25: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;== A correlated subquery relies on the main query for its processing.==&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;
Correlated subqueries rely on a value from the main query to retrieve its rows you will always see a column from the main query being referenced by the subquery.&lt;br /&gt;
9&amp;gt;&lt;br /&gt;
10&amp;gt;&lt;br /&gt;
11&amp;gt; CREATE TABLE authors(&lt;br /&gt;
12&amp;gt;    au_id          varchar(11),&lt;br /&gt;
13&amp;gt;    au_lname       varchar(40)       NOT NULL,&lt;br /&gt;
14&amp;gt;    au_fname       varchar(20)       NOT NULL,&lt;br /&gt;
15&amp;gt;    phone          char(12)          NOT NULL DEFAULT (&amp;quot;UNKNOWN&amp;quot;),&lt;br /&gt;
16&amp;gt;    address        varchar(40)           NULL,&lt;br /&gt;
17&amp;gt;    city           varchar(20)           NULL,&lt;br /&gt;
18&amp;gt;    state          char(2)               NULL,&lt;br /&gt;
19&amp;gt;    zip            char(5)               NULL,&lt;br /&gt;
20&amp;gt;    contract       bit               NOT NULL&lt;br /&gt;
21&amp;gt; )&lt;br /&gt;
22&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; CREATE TABLE titleauthor(&lt;br /&gt;
3&amp;gt;    au_id          varchar(20),&lt;br /&gt;
4&amp;gt;    title_id       varchar(20),&lt;br /&gt;
5&amp;gt;    au_ord         tinyint               NULL,&lt;br /&gt;
6&amp;gt;    royaltyper     int                   NULL&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; insert titleauthor values(&amp;quot;1&amp;quot;, &amp;quot;2&amp;quot;, 1, 60)&lt;br /&gt;
3&amp;gt; insert titleauthor values(&amp;quot;2&amp;quot;, &amp;quot;3&amp;quot;, 1, 100)&lt;br /&gt;
4&amp;gt; insert titleauthor values(&amp;quot;3&amp;quot;, &amp;quot;4&amp;quot;, 1, 100)&lt;br /&gt;
5&amp;gt; insert titleauthor values(&amp;quot;4&amp;quot;, &amp;quot;5&amp;quot;, 1, 100)&lt;br /&gt;
6&amp;gt; insert titleauthor values(&amp;quot;5&amp;quot;, &amp;quot;6&amp;quot;, 1, 100)&lt;br /&gt;
7&amp;gt; insert titleauthor values(&amp;quot;6&amp;quot;, &amp;quot;7&amp;quot;, 2, 40)&lt;br /&gt;
8&amp;gt; insert titleauthor values(&amp;quot;7&amp;quot;, &amp;quot;8&amp;quot;, 1, 100)&lt;br /&gt;
9&amp;gt; insert titleauthor values(&amp;quot;8&amp;quot;, &amp;quot;9&amp;quot;, 1, 100)&lt;br /&gt;
10&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&amp;gt;&lt;br /&gt;
2&amp;gt;      SELECT    DISTINCT au_lname, au_fname&lt;br /&gt;
3&amp;gt;      FROM      authors&lt;br /&gt;
4&amp;gt;      WHERE     10 IN (SELECT royaltyper&lt;br /&gt;
5&amp;gt;                FROM titleauthor&lt;br /&gt;
6&amp;gt;                 WHERE titleauthor.au_id = authors.au_id)&lt;br /&gt;
7&amp;gt; GO&lt;br /&gt;
au_lname                                 au_fname&lt;br /&gt;
---------------------------------------- --------------------&lt;br /&gt;
(0 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table titleauthor;&lt;br /&gt;
3&amp;gt; drop table authors;&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Correlated subquery using Group By==&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;&lt;br /&gt;
5&amp;gt;&lt;br /&gt;
6&amp;gt; CREATE TABLE Product(&lt;br /&gt;
7&amp;gt;     ProductID               int                NOT NULL,&lt;br /&gt;
8&amp;gt;     Name                    nvarchar(25)       NOT NULL,&lt;br /&gt;
9&amp;gt;     ProductNumber           nvarchar(25)               ,&lt;br /&gt;
10&amp;gt;     Color                   nvarchar(15)       NULL,&lt;br /&gt;
11&amp;gt;      StandardCost            money              NOT NULL,&lt;br /&gt;
12&amp;gt;      Size                    nvarchar(5)        NULL,&lt;br /&gt;
13&amp;gt;      Weight                  decimal(8, 2)      NULL,&lt;br /&gt;
14&amp;gt;      ProductLine             nchar(20)           NULL,&lt;br /&gt;
15&amp;gt;      SellStartDate           datetime           NOT NULL,&lt;br /&gt;
16&amp;gt;      SellEndDate             datetime           NULL&lt;br /&gt;
17&amp;gt;  )&lt;br /&gt;
18&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;&lt;br /&gt;
6&amp;gt; CREATE TABLE SalesOrderDetail(&lt;br /&gt;
7&amp;gt;     SalesOrderID            int                NOT NULL,&lt;br /&gt;
8&amp;gt;     SalesOrderDetailID      int                NOT NULL,&lt;br /&gt;
9&amp;gt;     CarrierTrackingNumber   nvarchar(25)       NULL,&lt;br /&gt;
10&amp;gt;     OrderQty                smallint           NOT NULL,&lt;br /&gt;
11&amp;gt;     ProductID               int                NOT NULL,&lt;br /&gt;
12&amp;gt;      SpecialOfferID          int                NOT NULL,&lt;br /&gt;
13&amp;gt;      UnitPrice               money              NOT NULL,&lt;br /&gt;
14&amp;gt;      UnitPriceDiscount       money              NOT NULL DEFAULT (0.0),&lt;br /&gt;
15&amp;gt;      LineTotal               AS ISNULL([UnitPrice] * (1.0 - [UnitPriceDiscount]) * [OrderQty], 0.0)&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; insert into SalesOrderDetail values (1,1,&amp;quot;1&amp;quot;,1,1,1,$1,$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;&lt;br /&gt;
3&amp;gt; insert into SalesOrderDetail values (2,2,&amp;quot;2&amp;quot;,2,2,2,$2,$2);&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 SalesOrderDetail values (3,3,&amp;quot;3&amp;quot;,3,3,3,$3,$3);&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 SalesOrderDetail values (4,4,&amp;quot;4&amp;quot;,4,4,4,$4,$4);&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 SalesOrderDetail values (5,5,&amp;quot;5&amp;quot;,5,5,5,$5,$5);&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 SalesOrderDetail values (6,6,&amp;quot;6&amp;quot;,6,6,6,$6,$6);&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 SalesOrderDetail values (7,7,&amp;quot;7&amp;quot;,7,7,7,$7,$7);&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 SalesOrderDetail values (8,8,&amp;quot;8&amp;quot;,8,8,8,$8,$8);&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 SalesOrderDetail values (9,9,&amp;quot;9&amp;quot;,9,9,9,$9,$9);&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; SELECT ProductID&lt;br /&gt;
6&amp;gt;   , Name&lt;br /&gt;
7&amp;gt; FROM Product AS P&lt;br /&gt;
8&amp;gt; WHERE 1 =&lt;br /&gt;
9&amp;gt;   (SELECT ProductID&lt;br /&gt;
10&amp;gt;   FROM SalesOrderDetail As SD&lt;br /&gt;
11&amp;gt;   WHERE P.ProductID = SD.ProductID&lt;br /&gt;
12&amp;gt;    GROUP BY ProductID)&lt;br /&gt;
13&amp;gt;  GO&lt;br /&gt;
ProductID   Name&lt;br /&gt;
----------- -------------------------&lt;br /&gt;
          1 Product A&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table Product;&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 SalesOrderDetail;&lt;br /&gt;
4&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Correlated subquery using TOP 1==&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 Product(&lt;br /&gt;
8&amp;gt;     ProductID               int                NOT NULL,&lt;br /&gt;
9&amp;gt;     Name                    nvarchar(25)       NOT NULL,&lt;br /&gt;
10&amp;gt;     ProductNumber           nvarchar(25)               ,&lt;br /&gt;
11&amp;gt;     Color                   nvarchar(15)       NULL,&lt;br /&gt;
12&amp;gt;     StandardCost            money              NOT NULL,&lt;br /&gt;
13&amp;gt;     Size                    nvarchar(5)        NULL,&lt;br /&gt;
14&amp;gt;     Weight                  decimal(8, 2)      NULL,&lt;br /&gt;
15&amp;gt;     ProductLine             nchar(20)           NULL,&lt;br /&gt;
16&amp;gt;     SellStartDate           datetime           NOT NULL,&lt;br /&gt;
17&amp;gt;     SellEndDate             datetime           NULL&lt;br /&gt;
18&amp;gt; )&lt;br /&gt;
19&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; 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;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&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;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&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;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&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;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&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;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&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;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&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;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&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;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&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;
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;&lt;br /&gt;
4&amp;gt; CREATE TABLE SalesOrderDetail(&lt;br /&gt;
5&amp;gt;     SalesOrderID            int                NOT NULL,&lt;br /&gt;
6&amp;gt;     SalesOrderDetailID      int                NOT NULL,&lt;br /&gt;
7&amp;gt;     CarrierTrackingNumber   nvarchar(25)       NULL,&lt;br /&gt;
8&amp;gt;     OrderQty                smallint           NOT NULL,&lt;br /&gt;
9&amp;gt;     ProductID               int                NOT NULL,&lt;br /&gt;
10&amp;gt;     SpecialOfferID          int                NOT NULL,&lt;br /&gt;
11&amp;gt;     UnitPrice               money              NOT NULL,&lt;br /&gt;
12&amp;gt;     UnitPriceDiscount       money              NOT NULL DEFAULT (0.0),&lt;br /&gt;
13&amp;gt;     LineTotal               AS ISNULL([UnitPrice] * (1.0 - [UnitPriceDiscount]) * [OrderQty], 0.0)&lt;br /&gt;
14&amp;gt; );&lt;br /&gt;
15&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; insert into SalesOrderDetail values (1,1,&amp;quot;1&amp;quot;,1,1,1,$1,$1);&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into SalesOrderDetail values (2,2,&amp;quot;2&amp;quot;,2,2,2,$2,$2);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into SalesOrderDetail values (3,3,&amp;quot;3&amp;quot;,3,3,3,$3,$3);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into SalesOrderDetail values (4,4,&amp;quot;4&amp;quot;,4,4,4,$4,$4);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into SalesOrderDetail values (5,5,&amp;quot;5&amp;quot;,5,5,5,$5,$5);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into SalesOrderDetail values (6,6,&amp;quot;6&amp;quot;,6,6,6,$6,$6);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into SalesOrderDetail values (7,7,&amp;quot;7&amp;quot;,7,7,7,$7,$7);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into SalesOrderDetail values (8,8,&amp;quot;8&amp;quot;,8,8,8,$8,$8);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into SalesOrderDetail values (9,9,&amp;quot;9&amp;quot;,9,9,9,$9,$9);&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 ProductID&lt;br /&gt;
3&amp;gt;   , Name&lt;br /&gt;
4&amp;gt; FROM Product AS P&lt;br /&gt;
5&amp;gt; WHERE 1 =&lt;br /&gt;
6&amp;gt;   (SELECT TOP 1 ProductID&lt;br /&gt;
7&amp;gt;   FROM SalesOrderDetail As SD&lt;br /&gt;
8&amp;gt;   WHERE P.ProductID = SD.ProductID)&lt;br /&gt;
9&amp;gt; GO&lt;br /&gt;
ProductID   Name&lt;br /&gt;
----------- -------------------------&lt;br /&gt;
          1 Product A&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table Product;&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 SalesOrderDetail;&lt;br /&gt;
4&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== using SELECT DISTINCT or a GROUP BY statement in the inner query==&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;&lt;br /&gt;
8&amp;gt;&lt;br /&gt;
9&amp;gt; CREATE TABLE Product(&lt;br /&gt;
10&amp;gt;     ProductID               int                NOT NULL,&lt;br /&gt;
11&amp;gt;     Name                    nvarchar(25)       NOT NULL,&lt;br /&gt;
12&amp;gt;     ProductNumber           nvarchar(25)               ,&lt;br /&gt;
13&amp;gt;     Color                   nvarchar(15)       NULL,&lt;br /&gt;
14&amp;gt;     StandardCost            money              NOT NULL,&lt;br /&gt;
15&amp;gt;     Size                    nvarchar(5)        NULL,&lt;br /&gt;
16&amp;gt;     Weight                  decimal(8, 2)      NULL,&lt;br /&gt;
17&amp;gt;     ProductLine             nchar(20)           NULL,&lt;br /&gt;
18&amp;gt;     SellStartDate           datetime           NOT NULL,&lt;br /&gt;
19&amp;gt;     SellEndDate             datetime           NULL&lt;br /&gt;
20&amp;gt; )&lt;br /&gt;
21&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; 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;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&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;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&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;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&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;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&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;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&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;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&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;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&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;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&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;
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;&lt;br /&gt;
4&amp;gt; CREATE TABLE SalesOrderDetail(&lt;br /&gt;
5&amp;gt;     SalesOrderID            int                NOT NULL,&lt;br /&gt;
6&amp;gt;     SalesOrderDetailID      int                NOT NULL,&lt;br /&gt;
7&amp;gt;     CarrierTrackingNumber   nvarchar(25)       NULL,&lt;br /&gt;
8&amp;gt;     OrderQty                smallint           NOT NULL,&lt;br /&gt;
9&amp;gt;     ProductID               int                NOT NULL,&lt;br /&gt;
10&amp;gt;     SpecialOfferID          int                NOT NULL,&lt;br /&gt;
11&amp;gt;     UnitPrice               money              NOT NULL,&lt;br /&gt;
12&amp;gt;     UnitPriceDiscount       money              NOT NULL DEFAULT (0.0),&lt;br /&gt;
13&amp;gt;     LineTotal               AS ISNULL([UnitPrice] * (1.0 - [UnitPriceDiscount]) * [OrderQty], 0.0)&lt;br /&gt;
14&amp;gt; );&lt;br /&gt;
15&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; insert into SalesOrderDetail values (1,1,&amp;quot;1&amp;quot;,1,1,1,$1,$1);&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into SalesOrderDetail values (2,2,&amp;quot;2&amp;quot;,2,2,2,$2,$2);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into SalesOrderDetail values (3,3,&amp;quot;3&amp;quot;,3,3,3,$3,$3);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into SalesOrderDetail values (4,4,&amp;quot;4&amp;quot;,4,4,4,$4,$4);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into SalesOrderDetail values (5,5,&amp;quot;5&amp;quot;,5,5,5,$5,$5);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into SalesOrderDetail values (6,6,&amp;quot;6&amp;quot;,6,6,6,$6,$6);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into SalesOrderDetail values (7,7,&amp;quot;7&amp;quot;,7,7,7,$7,$7);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into SalesOrderDetail values (8,8,&amp;quot;8&amp;quot;,8,8,8,$8,$8);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into SalesOrderDetail values (9,9,&amp;quot;9&amp;quot;,9,9,9,$9,$9);&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; SELECT ID&lt;br /&gt;
4&amp;gt;   , Name&lt;br /&gt;
5&amp;gt; FROM Product AS P&lt;br /&gt;
6&amp;gt; WHERE 1 =&lt;br /&gt;
7&amp;gt;   (SELECT DISTINCT ProductID&lt;br /&gt;
8&amp;gt;   FROM SalesOrderDetail As SD&lt;br /&gt;
9&amp;gt;   WHERE P.ProductID = SD.ProductID)&lt;br /&gt;
10&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table Product;&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 SalesOrderDetail;&lt;br /&gt;
4&amp;gt; GO&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>