<?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%2FSelect_Query%2FGroup_BY</id>
		<title>SQL Server/T-SQL/Select Query/Group BY - История изменений</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%2FSelect_Query%2FGroup_BY"/>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=SQL_Server/T-SQL/Select_Query/Group_BY&amp;action=history"/>
		<updated>2026-05-24T14:34:33Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.sqle.ru/index.php?title=SQL_Server/T-SQL/Select_Query/Group_BY&amp;diff=6052&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/Select_Query/Group_BY&amp;diff=6052&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://www.sqle.ru/index.php?title=SQL_Server/T-SQL/Select_Query/Group_BY&amp;diff=6053&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/Select_Query/Group_BY&amp;diff=6053&amp;oldid=prev"/>
				<updated>2010-05-26T10:21:07Z</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;==Combine MAX function with 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;
&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; SELECT City, MIN(Salary),MAX(Salary)&lt;br /&gt;
3&amp;gt; FROM Employee&lt;br /&gt;
4&amp;gt; WHERE ID BETWEEN 1 AND 10&lt;br /&gt;
5&amp;gt; GROUP BY City&lt;br /&gt;
6&amp;gt; GO&lt;br /&gt;
City&lt;br /&gt;
---------- ----------- -----------&lt;br /&gt;
New York         40420       90620&lt;br /&gt;
Toronto          24020       70060&lt;br /&gt;
Vancouver        14420       80026&lt;br /&gt;
(3 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; drop table employee&lt;br /&gt;
7&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;
==Combine MIN function with 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;
&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; SELECT City, MIN(Salary),MAX(Salary)&lt;br /&gt;
3&amp;gt; FROM Employee&lt;br /&gt;
4&amp;gt; WHERE ID BETWEEN 1 AND 10&lt;br /&gt;
5&amp;gt; GROUP BY City&lt;br /&gt;
6&amp;gt; GO&lt;br /&gt;
City&lt;br /&gt;
---------- ----------- -----------&lt;br /&gt;
New York         40420       90620&lt;br /&gt;
Toronto          24020       70060&lt;br /&gt;
Vancouver        14420       80026&lt;br /&gt;
(3 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; drop table employee&lt;br /&gt;
7&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;
==Count() and Sum() with group by and column alias==&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;
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; SELECT  City&lt;br /&gt;
3&amp;gt;       , SUM(Salary) As QtySum&lt;br /&gt;
4&amp;gt;       , COUNT(salary) As DetailCount&lt;br /&gt;
5&amp;gt; FROM Employee&lt;br /&gt;
6&amp;gt; GROUP BY City&lt;br /&gt;
7&amp;gt; GO&lt;br /&gt;
City       QtySum      DetailCount&lt;br /&gt;
---------- ----------- -----------&lt;br /&gt;
New York        171660           3&lt;br /&gt;
Toronto         154100           3&lt;br /&gt;
Vancouver       120466           3&lt;br /&gt;
(3 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;
==Count with &amp;quot;group by&amp;quot;==&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;
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; SELECT City, COUNT(*) &amp;quot;Employees&amp;quot;&lt;br /&gt;
3&amp;gt; FROM Employee&lt;br /&gt;
4&amp;gt; GROUP BY City&lt;br /&gt;
5&amp;gt; GO&lt;br /&gt;
City       Employees&lt;br /&gt;
---------- -----------&lt;br /&gt;
New York             3&lt;br /&gt;
Toronto              3&lt;br /&gt;
Vancouver            3&lt;br /&gt;
(3 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; drop table employee&lt;br /&gt;
4&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;
==GROUP BY builds different groups for all possible values (NULL, too!)==&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;&lt;br /&gt;
2&amp;gt; CREATE TABLE works_on        (emp_no       INTEGER NOT NULL,&lt;br /&gt;
3&amp;gt;                         project_no    CHAR(4) NOT NULL,&lt;br /&gt;
4&amp;gt;                         job CHAR (15) NULL,&lt;br /&gt;
5&amp;gt;                         enter_date    DATETIME NULL)&lt;br /&gt;
6&amp;gt;&lt;br /&gt;
7&amp;gt; insert into works_on values (1, &amp;quot;p1&amp;quot;, &amp;quot;analyst&amp;quot;, &amp;quot;1997.10.1&amp;quot;)&lt;br /&gt;
8&amp;gt; insert into works_on values (1, &amp;quot;p3&amp;quot;, &amp;quot;manager&amp;quot;, &amp;quot;1999.1.1&amp;quot;)&lt;br /&gt;
9&amp;gt; insert into works_on values (2, &amp;quot;p2&amp;quot;, &amp;quot;clerk&amp;quot;,   &amp;quot;1998.2.15&amp;quot;)&lt;br /&gt;
10&amp;gt; insert into works_on values (2, &amp;quot;p2&amp;quot;,  NULL,     &amp;quot;1998.6.1&amp;quot;)&lt;br /&gt;
11&amp;gt; insert into works_on values (3, &amp;quot;p2&amp;quot;,  NULL,     &amp;quot;1997.12.15&amp;quot;)&lt;br /&gt;
12&amp;gt; insert into works_on values (4, &amp;quot;p3&amp;quot;, &amp;quot;analyst&amp;quot;, &amp;quot;1998.10.15&amp;quot;)&lt;br /&gt;
13&amp;gt; insert into works_on values (5, &amp;quot;p1&amp;quot;, &amp;quot;manager&amp;quot;, &amp;quot;1998.4.15&amp;quot;)&lt;br /&gt;
14&amp;gt; insert into works_on values (6, &amp;quot;p1&amp;quot;,  NULL,     &amp;quot;1998.8.1&amp;quot;)&lt;br /&gt;
15&amp;gt; insert into works_on values (7, &amp;quot;p2&amp;quot;, &amp;quot;clerk&amp;quot;,   &amp;quot;1999.2.1&amp;quot;)&lt;br /&gt;
16&amp;gt; insert into works_on values (8, &amp;quot;p3&amp;quot;, &amp;quot;clerk&amp;quot;,   &amp;quot;1997.11.15&amp;quot;)&lt;br /&gt;
17&amp;gt; insert into works_on values (7, &amp;quot;p1&amp;quot;, &amp;quot;clerk&amp;quot;,   &amp;quot;1998.1.4&amp;quot;)&lt;br /&gt;
18&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;&lt;br /&gt;
2&amp;gt; -- GROUP BY builds different groups for all possible values (NULL, too!)&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt; SELECT project_no, job FROM works_on GROUP BY project_no, job&lt;br /&gt;
5&amp;gt; GO&lt;br /&gt;
project_no job&lt;br /&gt;
---------- ---------------&lt;br /&gt;
p1         NULL&lt;br /&gt;
p1         analyst&lt;br /&gt;
p1         clerk&lt;br /&gt;
p1         manager&lt;br /&gt;
p2         NULL&lt;br /&gt;
p2         clerk&lt;br /&gt;
p3         analyst&lt;br /&gt;
p3         clerk&lt;br /&gt;
p3         manager&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table works_on&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;
==GROUP BY clause with an aggregator &amp;quot;SUM()&amp;quot;==&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;
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; --GROUP BY clause with an aggregator &amp;quot;SUM()&amp;quot;.&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt; SELECT region, SUM(Salary)&lt;br /&gt;
5&amp;gt; FROM Employee&lt;br /&gt;
6&amp;gt; WHERE ID BETWEEN 1 AND 10&lt;br /&gt;
7&amp;gt; GROUP BY Region&lt;br /&gt;
8&amp;gt; GO&lt;br /&gt;
region&lt;br /&gt;
------ -----------&lt;br /&gt;
N           151120&lt;br /&gt;
W           295106&lt;br /&gt;
(2 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; drop table employee&lt;br /&gt;
4&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;
==Simple &amp;quot;group by&amp;quot; demo==&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; SELECT Name&lt;br /&gt;
3&amp;gt; FROM Employee&lt;br /&gt;
4&amp;gt; GROUP BY Name&lt;br /&gt;
5&amp;gt; GO&lt;br /&gt;
Name&lt;br /&gt;
----------&lt;br /&gt;
Alison&lt;br /&gt;
Celia&lt;br /&gt;
Chris&lt;br /&gt;
David&lt;br /&gt;
James&lt;br /&gt;
Jason&lt;br /&gt;
Linda&lt;br /&gt;
Mary&lt;br /&gt;
Robert&lt;br /&gt;
(9 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;
==Subquery as one column==&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; create table job(&lt;br /&gt;
3&amp;gt;     ID              int,&lt;br /&gt;
4&amp;gt;     title nvarchar  (10),&lt;br /&gt;
5&amp;gt;     averageSalary   int)&lt;br /&gt;
6&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; insert into job(ID, title, averageSalary) values(1,&amp;quot;Developer&amp;quot;,3000)&lt;br /&gt;
5&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into job(ID, title, averageSalary) values(2,&amp;quot;Tester&amp;quot;, 4000)&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into job(ID, title, averageSalary) values(3,&amp;quot;Designer&amp;quot;, 5000)&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into job(ID, title, averageSalary) values(4,&amp;quot;Programmer&amp;quot;, 6000)&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 job&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
ID          title      averageSalary&lt;br /&gt;
----------- ---------- -------------&lt;br /&gt;
          1 Developer           3000&lt;br /&gt;
          2 Tester              4000&lt;br /&gt;
          3 Designer            5000&lt;br /&gt;
          4 Programmer          6000&lt;br /&gt;
(4 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; SELECT ID&lt;br /&gt;
3&amp;gt;        , (SELECT Title FROM job&lt;br /&gt;
4&amp;gt;           WHERE Employee.ID = Job.ID)&lt;br /&gt;
5&amp;gt;             AS Title&lt;br /&gt;
6&amp;gt; FROM Employee&lt;br /&gt;
7&amp;gt; GO&lt;br /&gt;
ID          Title&lt;br /&gt;
----------- ----------&lt;br /&gt;
          1 Developer&lt;br /&gt;
          2 Tester&lt;br /&gt;
          3 Designer&lt;br /&gt;
          4 Programmer&lt;br /&gt;
          5 NULL&lt;br /&gt;
          6 NULL&lt;br /&gt;
          7 NULL&lt;br /&gt;
          8 NULL&lt;br /&gt;
          9 NULL&lt;br /&gt;
(9 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;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==When grouping on more than one column, every unique combination of grouped values produces a row in the result set==&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;
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; -- When grouping on more than one column, every unique combination of grouped values produces a row in the result set.&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt; SELECT City&lt;br /&gt;
5&amp;gt;       , Region&lt;br /&gt;
6&amp;gt; FROM Employee&lt;br /&gt;
7&amp;gt; GROUP BY City, Region&lt;br /&gt;
8&amp;gt; ORDER BY City, Region&lt;br /&gt;
9&amp;gt; GO&lt;br /&gt;
City       Region&lt;br /&gt;
---------- ------&lt;br /&gt;
New York   N&lt;br /&gt;
New York   W&lt;br /&gt;
Toronto    N&lt;br /&gt;
Toronto    W&lt;br /&gt;
Vancouver  N&lt;br /&gt;
Vancouver  W&lt;br /&gt;
(6 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; drop table employee&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>