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

	<entry>
		<id>http://www.sqle.ru/index.php?title=SQL_Server/T-SQL/Select_Query/HAVING&amp;diff=6060&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/HAVING&amp;diff=6060&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/HAVING&amp;diff=6061&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/HAVING&amp;diff=6061&amp;oldid=prev"/>
				<updated>2010-05-26T10:21:09Z</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 two conditions in Having clause==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt; create table Billings (&lt;br /&gt;
5&amp;gt;     BankerID           INTEGER,&lt;br /&gt;
6&amp;gt;     BillingNumber      INTEGER,&lt;br /&gt;
7&amp;gt;     BillingDate        datetime,&lt;br /&gt;
8&amp;gt;     BillingTotal       INTEGER,&lt;br /&gt;
9&amp;gt;     TermsID            INTEGER,&lt;br /&gt;
10&amp;gt;     BillingDueDate     datetime ,&lt;br /&gt;
11&amp;gt;     PaymentTotal       INTEGER,&lt;br /&gt;
12&amp;gt;     CreditTotal        INTEGER&lt;br /&gt;
13&amp;gt;&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 Billings VALUES (1, 1, &amp;quot;2005-01-22&amp;quot;, 165, 1,&amp;quot;2005-04-22&amp;quot;,123,321);&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (2, 2, &amp;quot;2001-02-21&amp;quot;, 165, 1,&amp;quot;2002-02-22&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (3, 3, &amp;quot;2003-05-02&amp;quot;, 165, 1,&amp;quot;2005-04-12&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (4, 4, &amp;quot;1999-03-12&amp;quot;, 165, 1,&amp;quot;2005-04-18&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (5, 5, &amp;quot;2000-04-23&amp;quot;, 165, 1,&amp;quot;2005-04-17&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (6, 6, &amp;quot;2001-06-14&amp;quot;, 165, 1,&amp;quot;2005-04-18&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (7, 7, &amp;quot;2002-07-15&amp;quot;, 165, 1,&amp;quot;2005-04-19&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (8, 8, &amp;quot;2003-08-16&amp;quot;, 165, 1,&amp;quot;2005-04-20&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (9, 9, &amp;quot;2004-09-17&amp;quot;, 165, 1,&amp;quot;2005-04-21&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (0, 0, &amp;quot;2005-10-18&amp;quot;, 165, 1,&amp;quot;2005-04-22&amp;quot;,123,321);&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 Bankers(&lt;br /&gt;
5&amp;gt;    BankerID             Integer,&lt;br /&gt;
6&amp;gt;    BankerName           VARCHAR(20),&lt;br /&gt;
7&amp;gt;    BankerContactLName   VARCHAR(20),&lt;br /&gt;
8&amp;gt;    BankerContactFName   VARCHAR(20),&lt;br /&gt;
9&amp;gt;    BankerCity           VARCHAR(20),&lt;br /&gt;
10&amp;gt;    BankerState          VARCHAR(20),&lt;br /&gt;
11&amp;gt;    BankerZipCode        VARCHAR(20),&lt;br /&gt;
12&amp;gt;    BankerPhone          VARCHAR(20)&lt;br /&gt;
13&amp;gt; )&lt;br /&gt;
14&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; insert into Bankers values (1, &amp;quot;ABC Inc.&amp;quot;,&amp;quot;Joe&amp;quot;,&amp;quot;Smith&amp;quot;,&amp;quot;Vancouver&amp;quot;,&amp;quot;BC&amp;quot;,&amp;quot;11111&amp;quot;,&amp;quot;111-111-1111&amp;quot;);&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (2, &amp;quot;DEF Inc.&amp;quot;,&amp;quot;Red&amp;quot;,&amp;quot;Rice&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;DE&amp;quot;,&amp;quot;22222&amp;quot;,&amp;quot;222-222-2222&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (3, &amp;quot;HJI Inc.&amp;quot;,&amp;quot;Kit&amp;quot;,&amp;quot;Cat&amp;quot;,  &amp;quot;Paris&amp;quot;,    &amp;quot;CA&amp;quot;,&amp;quot;33333&amp;quot;,&amp;quot;333-333-3333&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (4, &amp;quot;QWE Inc.&amp;quot;,&amp;quot;Git&amp;quot;,&amp;quot;Black&amp;quot;,&amp;quot;Regina&amp;quot;,   &amp;quot;ER&amp;quot;,&amp;quot;44444&amp;quot;,&amp;quot;444-444-4444&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (5, &amp;quot;RTY Inc.&amp;quot;,&amp;quot;Wil&amp;quot;,&amp;quot;Lee&amp;quot;,  &amp;quot;Toronto&amp;quot;,  &amp;quot;YU&amp;quot;,&amp;quot;55555&amp;quot;,&amp;quot;555-555-5555&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (6, &amp;quot;YUI Inc.&amp;quot;,&amp;quot;Ted&amp;quot;,&amp;quot;Larry&amp;quot;,&amp;quot;Calgary&amp;quot;,  &amp;quot;TY&amp;quot;,&amp;quot;66666&amp;quot;,&amp;quot;666-666-6666&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (7, &amp;quot;OIP Inc.&amp;quot;,&amp;quot;Yam&amp;quot;,&amp;quot;Act&amp;quot;,  &amp;quot;San Franc&amp;quot;,&amp;quot;FG&amp;quot;,&amp;quot;77777&amp;quot;,&amp;quot;777-777-7777&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (8, &amp;quot;SAD Inc.&amp;quot;,&amp;quot;Hit&amp;quot;,&amp;quot;Eat&amp;quot;,  &amp;quot;Orland&amp;quot;,   &amp;quot;PO&amp;quot;,&amp;quot;88888&amp;quot;,&amp;quot;888-888-8888&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (9, &amp;quot;DFG Inc.&amp;quot;,&amp;quot;Sad&amp;quot;,&amp;quot;Lee&amp;quot;,  &amp;quot;Wisler&amp;quot;,   &amp;quot;PL&amp;quot;,&amp;quot;99999&amp;quot;,&amp;quot;999-999-9999&amp;quot;);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into Bankers values (0, &amp;quot;GHJ Inc.&amp;quot;,&amp;quot;Bit&amp;quot;,&amp;quot;Lee&amp;quot;,  &amp;quot;Ticker&amp;quot;,   &amp;quot;MN&amp;quot;,&amp;quot;00000&amp;quot;,&amp;quot;000-000-0000&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; SELECT BillingDate, COUNT(*) AS BillingQty, SUM(BillingTotal) AS BillingSum&lt;br /&gt;
4&amp;gt; FROM Billings&lt;br /&gt;
5&amp;gt; WHERE BillingDate BETWEEN &amp;quot;2002-05-01&amp;quot; AND &amp;quot;2002-05-31&amp;quot;&lt;br /&gt;
6&amp;gt; GROUP BY BillingDate&lt;br /&gt;
7&amp;gt; HAVING COUNT(*) &amp;gt; 1&lt;br /&gt;
8&amp;gt;    AND SUM(BillingTotal) &amp;gt; 100&lt;br /&gt;
9&amp;gt; ORDER BY BillingDate DESC&lt;br /&gt;
10&amp;gt; GO&lt;br /&gt;
BillingDate             BillingQty  BillingSum&lt;br /&gt;
----------------------- ----------- -----------&lt;br /&gt;
(0 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table Billings;&lt;br /&gt;
3&amp;gt; drop table Bankers;&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==HAVING clause can also be used without aggregates==&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;&lt;br /&gt;
3&amp;gt; CREATE TABLE works_on        (emp_no       INTEGER NOT NULL,&lt;br /&gt;
4&amp;gt;                         project_no    CHAR(4) NOT NULL,&lt;br /&gt;
5&amp;gt;                         job CHAR (15) NULL,&lt;br /&gt;
6&amp;gt;                         enter_date    DATETIME NULL)&lt;br /&gt;
7&amp;gt; GO&lt;br /&gt;
1&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;
2&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;
3&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;
4&amp;gt; insert into works_on values (2, &amp;quot;p2&amp;quot;,  NULL,     &amp;quot;1998.6.1&amp;quot;)&lt;br /&gt;
5&amp;gt; insert into works_on values (3, &amp;quot;p2&amp;quot;,  NULL,     &amp;quot;1997.12.15&amp;quot;)&lt;br /&gt;
6&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;
7&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;
8&amp;gt; insert into works_on values (6, &amp;quot;p1&amp;quot;,  NULL,     &amp;quot;1998.8.1&amp;quot;)&lt;br /&gt;
9&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;
10&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;
11&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;
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; -- HAVING clause can also be used without aggregates&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; SELECT job FROM works_on GROUP BY job HAVING job LIKE &amp;quot;M%&amp;quot;&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
job&lt;br /&gt;
---------------&lt;br /&gt;
manager&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; drop table works_on&lt;br /&gt;
2&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;
==HAVING with the aggregate function COUNT(*)==&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 works_on        (emp_no       INTEGER NOT NULL,&lt;br /&gt;
2&amp;gt;                         project_no    CHAR(4) NOT NULL,&lt;br /&gt;
3&amp;gt;                         job CHAR (15) NULL,&lt;br /&gt;
4&amp;gt;                         enter_date    DATETIME NULL)&lt;br /&gt;
5&amp;gt; GO&lt;br /&gt;
1&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;
2&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;
3&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;
4&amp;gt; insert into works_on values (2, &amp;quot;p2&amp;quot;,  NULL,     &amp;quot;1998.6.1&amp;quot;)&lt;br /&gt;
5&amp;gt; insert into works_on values (3, &amp;quot;p2&amp;quot;,  NULL,     &amp;quot;1997.12.15&amp;quot;)&lt;br /&gt;
6&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;
7&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;
8&amp;gt; insert into works_on values (6, &amp;quot;p1&amp;quot;,  NULL,     &amp;quot;1998.8.1&amp;quot;)&lt;br /&gt;
9&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;
10&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;
11&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;
12&amp;gt; -- HAVING with the aggregate function COUNT(*).&lt;br /&gt;
13&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; SELECT project_no FROM works_on GROUP BY project_no HAVING COUNT(*) &amp;lt; 4&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
project_no&lt;br /&gt;
----------&lt;br /&gt;
p3&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; drop table works_on&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&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;
==Placing Conditions on Groups with the HAVING Clause==&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; -- Placing Conditions on Groups with the HAVING Clause&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt;&lt;br /&gt;
5&amp;gt; SELECT City, COUNT(*) AS Number&lt;br /&gt;
6&amp;gt; FROM Employee&lt;br /&gt;
7&amp;gt; WHERE ID != 5&lt;br /&gt;
8&amp;gt; GROUP BY City&lt;br /&gt;
9&amp;gt; GO&lt;br /&gt;
City       Number&lt;br /&gt;
---------- -----------&lt;br /&gt;
New York             3&lt;br /&gt;
Toronto              3&lt;br /&gt;
Vancouver            2&lt;br /&gt;
(3 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; SELECT city, COUNT(*) AS Reports&lt;br /&gt;
3&amp;gt; FROM Employee&lt;br /&gt;
4&amp;gt; GROUP BY City&lt;br /&gt;
5&amp;gt; HAVING COUNT(*) &amp;gt; 1&lt;br /&gt;
6&amp;gt; GO&lt;br /&gt;
city       Reports&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;&lt;br /&gt;
4&amp;gt; drop table employee&lt;br /&gt;
5&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;
==Use SUM function with having clause==&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 SUM(Salary) AS Total&lt;br /&gt;
3&amp;gt; FROM Employee&lt;br /&gt;
4&amp;gt; GROUP BY City&lt;br /&gt;
5&amp;gt; HAVING SUM(Salary) &amp;gt; 3000&lt;br /&gt;
6&amp;gt; GO&lt;br /&gt;
Total&lt;br /&gt;
-----------&lt;br /&gt;
     171660&lt;br /&gt;
     154100&lt;br /&gt;
     120466&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;
==Using HAVING Clause as a where clause==&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;&lt;br /&gt;
3&amp;gt; --The HAVING Clause&lt;br /&gt;
4&amp;gt;&lt;br /&gt;
5&amp;gt; SELECT SUM(salary) FROM employee&lt;br /&gt;
6&amp;gt; HAVING SUM(salary) &amp;gt; 100000&lt;br /&gt;
7&amp;gt;&lt;br /&gt;
8&amp;gt;&lt;br /&gt;
9&amp;gt;&lt;br /&gt;
10&amp;gt; drop table employee&lt;br /&gt;
11&amp;gt; GO&lt;br /&gt;
-----------&lt;br /&gt;
     446226&lt;br /&gt;
(1 rows affected)&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>