<?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%2FAnalytical_Functions%2FCUBE</id>
		<title>SQL Server/T-SQL Tutorial/Analytical Functions/CUBE - История изменений</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%2FAnalytical_Functions%2FCUBE"/>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Analytical_Functions/CUBE&amp;action=history"/>
		<updated>2026-05-24T08:50:00Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Analytical_Functions/CUBE&amp;diff=6390&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/Analytical_Functions/CUBE&amp;diff=6390&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/Analytical_Functions/CUBE&amp;diff=6391&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/Analytical_Functions/CUBE&amp;diff=6391&amp;oldid=prev"/>
				<updated>2010-05-26T10:22:52Z</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 summary query that includes a final summary row with &amp;quot;WITH CUBE&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;
3&amp;gt;&lt;br /&gt;
4&amp;gt;&lt;br /&gt;
5&amp;gt; create table Billings (&lt;br /&gt;
6&amp;gt;     BankerID           INTEGER,&lt;br /&gt;
7&amp;gt;     BillingNumber      INTEGER,&lt;br /&gt;
8&amp;gt;     BillingDate        datetime,&lt;br /&gt;
9&amp;gt;     BillingTotal       INTEGER,&lt;br /&gt;
10&amp;gt;     TermsID            INTEGER,&lt;br /&gt;
11&amp;gt;     BillingDueDate     datetime ,&lt;br /&gt;
12&amp;gt;     PaymentTotal       INTEGER,&lt;br /&gt;
13&amp;gt;     CreditTotal        INTEGER&lt;br /&gt;
14&amp;gt;&lt;br /&gt;
15&amp;gt; );&lt;br /&gt;
16&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; 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 BankerID, COUNT(*) AS BillingCount,&lt;br /&gt;
4&amp;gt;     SUM(BillingTotal) AS BillingTotal&lt;br /&gt;
5&amp;gt; FROM Billings&lt;br /&gt;
6&amp;gt; GROUP BY BankerID WITH CUBE&lt;br /&gt;
7&amp;gt; GO&lt;br /&gt;
BankerID    BillingCount BillingTotal&lt;br /&gt;
----------- ------------ ------------&lt;br /&gt;
          0            1          165&lt;br /&gt;
          1            1          165&lt;br /&gt;
          2            1          165&lt;br /&gt;
          3            1          165&lt;br /&gt;
          4            1          165&lt;br /&gt;
          5            1          165&lt;br /&gt;
          6            1          165&lt;br /&gt;
          7            1          165&lt;br /&gt;
          8            1          165&lt;br /&gt;
          9            1          165&lt;br /&gt;
       NULL           10         1650&lt;br /&gt;
(11 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;
1&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== A summary query that includes a summary row for each set of groups==&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;&lt;br /&gt;
7&amp;gt;&lt;br /&gt;
8&amp;gt; create table Billings (&lt;br /&gt;
9&amp;gt;     BankerID           INTEGER,&lt;br /&gt;
10&amp;gt;     BillingNumber      INTEGER,&lt;br /&gt;
11&amp;gt;     BillingDate        datetime,&lt;br /&gt;
12&amp;gt;     BillingTotal       INTEGER,&lt;br /&gt;
13&amp;gt;     TermsID            INTEGER,&lt;br /&gt;
14&amp;gt;     BillingDueDate     datetime ,&lt;br /&gt;
15&amp;gt;     PaymentTotal       INTEGER,&lt;br /&gt;
16&amp;gt;     CreditTotal        INTEGER&lt;br /&gt;
17&amp;gt;&lt;br /&gt;
18&amp;gt; );&lt;br /&gt;
19&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; SELECT BankerState, BankerCity, COUNT(*) AS QtyBankers&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt; FROM Bankers&lt;br /&gt;
5&amp;gt; WHERE BankerState IN (&amp;quot;IA&amp;quot;, &amp;quot;NJ&amp;quot;)&lt;br /&gt;
6&amp;gt; GROUP BY BankerState, BankerCity WITH CUBE&lt;br /&gt;
7&amp;gt; ORDER BY BankerState DESC, BankerCity DESC&lt;br /&gt;
8&amp;gt; GO&lt;br /&gt;
BankerState          BankerCity           QtyBankers&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&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Creating the Vbase_cube View to Hide the CUBE Query Complexity==&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;
3&amp;gt;&lt;br /&gt;
4&amp;gt; CREATE TABLE employee(&lt;br /&gt;
5&amp;gt;    id          INTEGER NOT NULL PRIMARY KEY,&lt;br /&gt;
6&amp;gt;    first_name  VARCHAR(10),&lt;br /&gt;
7&amp;gt;    last_name   VARCHAR(10),&lt;br /&gt;
8&amp;gt;    salary      DECIMAL(10,2),&lt;br /&gt;
9&amp;gt;    start_Date  DATETIME,&lt;br /&gt;
10&amp;gt;    region      VARCHAR(10),&lt;br /&gt;
11&amp;gt;    city        VARCHAR(20),&lt;br /&gt;
12&amp;gt;    managerid   INTEGER&lt;br /&gt;
13&amp;gt; );&lt;br /&gt;
14&amp;gt; GO&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (1, &amp;quot;Jason&amp;quot; ,  &amp;quot;Martin&amp;quot;, 5890,&amp;quot;2005-03-22&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Vancouver&amp;quot;,3);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (2, &amp;quot;Alison&amp;quot;,  &amp;quot;Mathews&amp;quot;,4789,&amp;quot;2003-07-21&amp;quot;,&amp;quot;South&amp;quot;,&amp;quot;Utown&amp;quot;,4);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (3, &amp;quot;James&amp;quot; ,  &amp;quot;Smith&amp;quot;,  6678,&amp;quot;2001-12-01&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Paris&amp;quot;,5);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (4, &amp;quot;Celia&amp;quot; ,  &amp;quot;Rice&amp;quot;,   5567,&amp;quot;2006-03-03&amp;quot;,&amp;quot;South&amp;quot;,&amp;quot;London&amp;quot;,6);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (5, &amp;quot;Robert&amp;quot;,  &amp;quot;Black&amp;quot;,  4467,&amp;quot;2004-07-02&amp;quot;,&amp;quot;East&amp;quot;,&amp;quot;Newton&amp;quot;,7);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (6, &amp;quot;Linda&amp;quot; ,  &amp;quot;Green&amp;quot; , 6456,&amp;quot;2002-05-19&amp;quot;,&amp;quot;East&amp;quot;,&amp;quot;Calgary&amp;quot;,8);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (7, &amp;quot;David&amp;quot; ,  &amp;quot;Larry&amp;quot;,  5345,&amp;quot;2008-03-18&amp;quot;,&amp;quot;West&amp;quot;,&amp;quot;New York&amp;quot;,9);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (8, &amp;quot;James&amp;quot; ,  &amp;quot;Cat&amp;quot;,    4234,&amp;quot;2007-07-17&amp;quot;,&amp;quot;West&amp;quot;,&amp;quot;Regina&amp;quot;,9);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (9, &amp;quot;Joan&amp;quot;  ,  &amp;quot;Act&amp;quot;,    6123,&amp;quot;2001-04-16&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Toronto&amp;quot;,10);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; select * from employee;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
id          first_name last_name  salary       start_Date              region     city                 managerid&lt;br /&gt;
----------- ---------- ---------- ------------ ----------------------- ---------- -------------------- -----------&lt;br /&gt;
          1 Jason      Martin          5890.00 2005-03-22 00:00:00.000 North      Vancouver                      3&lt;br /&gt;
          2 Alison     Mathews         4789.00 2003-07-21 00:00:00.000 South      Utown                          4&lt;br /&gt;
          3 James      Smith           6678.00 2001-12-01 00:00:00.000 North      Paris                          5&lt;br /&gt;
          4 Celia      Rice            5567.00 2006-03-03 00:00:00.000 South      London                         6&lt;br /&gt;
          5 Robert     Black           4467.00 2004-07-02 00:00:00.000 East       Newton                         7&lt;br /&gt;
          6 Linda      Green           6456.00 2002-05-19 00:00:00.000 East       Calgary                        8&lt;br /&gt;
          7 David      Larry           5345.00 2008-03-18 00:00:00.000 West       New York                       9&lt;br /&gt;
          8 James      Cat             4234.00 2007-07-17 00:00:00.000 West       Regina                         9&lt;br /&gt;
          9 Joan       Act             6123.00 2001-04-16 00:00:00.000 North      Toronto                       10&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt; CREATE VIEW Vbase_cube&lt;br /&gt;
5&amp;gt; AS&lt;br /&gt;
6&amp;gt; SELECT&lt;br /&gt;
7&amp;gt;   ID,&lt;br /&gt;
8&amp;gt;   GROUPING(ID)      AS Grp_Cust,&lt;br /&gt;
9&amp;gt;   YEAR(Start_Date)           AS Order_Year,&lt;br /&gt;
10&amp;gt;   GROUPING(YEAR(Start_Date)) AS Grp_Year,&lt;br /&gt;
11&amp;gt;   COUNT(*) as Order_Count&lt;br /&gt;
12&amp;gt; FROM&lt;br /&gt;
13&amp;gt;   Employee&lt;br /&gt;
14&amp;gt; GROUP BY&lt;br /&gt;
15&amp;gt;   ID,&lt;br /&gt;
16&amp;gt;   YEAR(Start_Date)&lt;br /&gt;
17&amp;gt; WITH CUBE&lt;br /&gt;
18&amp;gt; GO&lt;br /&gt;
1&amp;gt; --Selecting All Rows from the Vbase_cube View&lt;br /&gt;
2&amp;gt; SELECT&lt;br /&gt;
3&amp;gt;   *&lt;br /&gt;
4&amp;gt; FROM&lt;br /&gt;
5&amp;gt;   Vbase_cube&lt;br /&gt;
6&amp;gt; GO&lt;br /&gt;
ID          Grp_Cust Order_Year  Grp_Year Order_Count&lt;br /&gt;
----------- -------- ----------- -------- -----------&lt;br /&gt;
          1        0        2005        0           1&lt;br /&gt;
          1        0        NULL        1           1&lt;br /&gt;
          2        0        2003        0           1&lt;br /&gt;
          2        0        NULL        1           1&lt;br /&gt;
          3        0        2001        0           1&lt;br /&gt;
          3        0        NULL        1           1&lt;br /&gt;
          4        0        2006        0           1&lt;br /&gt;
          4        0        NULL        1           1&lt;br /&gt;
          5        0        2004        0           1&lt;br /&gt;
          5        0        NULL        1           1&lt;br /&gt;
          6        0        2002        0           1&lt;br /&gt;
          6        0        NULL        1           1&lt;br /&gt;
          7        0        2008        0           1&lt;br /&gt;
          7        0        NULL        1           1&lt;br /&gt;
          8        0        2007        0           1&lt;br /&gt;
          8        0        NULL        1           1&lt;br /&gt;
          9        0        2001        0           1&lt;br /&gt;
          9        0        NULL        1           1&lt;br /&gt;
       NULL        1        NULL        1           9&lt;br /&gt;
       NULL        1        2001        0           2&lt;br /&gt;
       NULL        1        2002        0           1&lt;br /&gt;
       NULL        1        2003        0           1&lt;br /&gt;
       NULL        1        2004        0           1&lt;br /&gt;
       NULL        1        2005        0           1&lt;br /&gt;
       NULL        1        2006        0           1&lt;br /&gt;
       NULL        1        2007        0           1&lt;br /&gt;
       NULL        1        2008        0           1&lt;br /&gt;
(27 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop view Vbase_cube&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 employee;&lt;br /&gt;
4&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== CUBE performs this rollup for every combination of grouped column values.==&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;
The CUBE operator is an expanded version of the ROLLUP operator.&lt;br /&gt;
&lt;br /&gt;
7&amp;gt; CREATE TABLE employee(&lt;br /&gt;
8&amp;gt;    id          INTEGER NOT NULL PRIMARY KEY,&lt;br /&gt;
9&amp;gt;    first_name  VARCHAR(10),&lt;br /&gt;
10&amp;gt;    last_name   VARCHAR(10),&lt;br /&gt;
11&amp;gt;    salary      DECIMAL(10,2),&lt;br /&gt;
12&amp;gt;    start_Date  DATETIME,&lt;br /&gt;
13&amp;gt;    region      VARCHAR(10),&lt;br /&gt;
14&amp;gt;    city        VARCHAR(20),&lt;br /&gt;
15&amp;gt;    managerid   INTEGER&lt;br /&gt;
16&amp;gt; );&lt;br /&gt;
17&amp;gt; GO&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (1, &amp;quot;Jason&amp;quot; ,  &amp;quot;Martin&amp;quot;, 5890,&amp;quot;2005-03-22&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Vancouver&amp;quot;,3);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (2, &amp;quot;Alison&amp;quot;,  &amp;quot;Mathews&amp;quot;,4789,&amp;quot;2003-07-21&amp;quot;,&amp;quot;South&amp;quot;,&amp;quot;Utown&amp;quot;,4);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (3, &amp;quot;James&amp;quot; ,  &amp;quot;Smith&amp;quot;,  6678,&amp;quot;2001-12-01&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Paris&amp;quot;,5);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (4, &amp;quot;Celia&amp;quot; ,  &amp;quot;Rice&amp;quot;,   5567,&amp;quot;2006-03-03&amp;quot;,&amp;quot;South&amp;quot;,&amp;quot;London&amp;quot;,6);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (5, &amp;quot;Robert&amp;quot;,  &amp;quot;Black&amp;quot;,  4467,&amp;quot;2004-07-02&amp;quot;,&amp;quot;East&amp;quot;,&amp;quot;Newton&amp;quot;,7);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (6, &amp;quot;Linda&amp;quot; ,  &amp;quot;Green&amp;quot; , 6456,&amp;quot;2002-05-19&amp;quot;,&amp;quot;East&amp;quot;,&amp;quot;Calgary&amp;quot;,8);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (7, &amp;quot;David&amp;quot; ,  &amp;quot;Larry&amp;quot;,  5345,&amp;quot;2008-03-18&amp;quot;,&amp;quot;West&amp;quot;,&amp;quot;New York&amp;quot;,9);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (8, &amp;quot;James&amp;quot; ,  &amp;quot;Cat&amp;quot;,    4234,&amp;quot;2007-07-17&amp;quot;,&amp;quot;West&amp;quot;,&amp;quot;Regina&amp;quot;,9);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (9, &amp;quot;Joan&amp;quot;  ,  &amp;quot;Act&amp;quot;,    6123,&amp;quot;2001-04-16&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Toronto&amp;quot;,10);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; select * from employee;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
id          first_name last_name  salary       start_Date              region     city                 managerid&lt;br /&gt;
----------- ---------- ---------- ------------ ----------------------- ---------- -------------------- -----------&lt;br /&gt;
          1 Jason      Martin          5890.00 2005-03-22 00:00:00.000 North      Vancouver                      3&lt;br /&gt;
          2 Alison     Mathews         4789.00 2003-07-21 00:00:00.000 South      Utown                          4&lt;br /&gt;
          3 James      Smith           6678.00 2001-12-01 00:00:00.000 North      Paris                          5&lt;br /&gt;
          4 Celia      Rice            5567.00 2006-03-03 00:00:00.000 South      London                         6&lt;br /&gt;
          5 Robert     Black           4467.00 2004-07-02 00:00:00.000 East       Newton                         7&lt;br /&gt;
          6 Linda      Green           6456.00 2002-05-19 00:00:00.000 East       Calgary                        8&lt;br /&gt;
          7 David      Larry           5345.00 2008-03-18 00:00:00.000 West       New York                       9&lt;br /&gt;
          8 James      Cat             4234.00 2007-07-17 00:00:00.000 West       Regina                         9&lt;br /&gt;
          9 Joan       Act             6123.00 2001-04-16 00:00:00.000 North      Toronto                       10&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt; SELECT region, city, SUM(salary)&lt;br /&gt;
5&amp;gt; FROM Employee&lt;br /&gt;
6&amp;gt; GROUP BY region, city&lt;br /&gt;
7&amp;gt; WITH CUBE&lt;br /&gt;
8&amp;gt; GO&lt;br /&gt;
region     city&lt;br /&gt;
---------- -------------------- ----------------------------------------&lt;br /&gt;
East       Calgary                                               6456.00&lt;br /&gt;
East       Newton                                                4467.00&lt;br /&gt;
East       NULL                                                 10923.00&lt;br /&gt;
North      Paris                                                 6678.00&lt;br /&gt;
North      Toronto                                               6123.00&lt;br /&gt;
North      Vancouver                                             5890.00&lt;br /&gt;
North      NULL                                                 18691.00&lt;br /&gt;
South      London                                                5567.00&lt;br /&gt;
South      Utown                                                 4789.00&lt;br /&gt;
South      NULL                                                 10356.00&lt;br /&gt;
West       New York                                              5345.00&lt;br /&gt;
West       Regina                                                4234.00&lt;br /&gt;
West       NULL                                                  9579.00&lt;br /&gt;
NULL       NULL                                                 49549.00&lt;br /&gt;
NULL       Calgary                                               6456.00&lt;br /&gt;
NULL       London                                                5567.00&lt;br /&gt;
NULL       New York                                              5345.00&lt;br /&gt;
NULL       Newton                                                4467.00&lt;br /&gt;
NULL       Paris                                                 6678.00&lt;br /&gt;
NULL       Regina                                                4234.00&lt;br /&gt;
NULL       Toronto                                               6123.00&lt;br /&gt;
NULL       Utown                                                 4789.00&lt;br /&gt;
NULL       Vancouver                                             5890.00&lt;br /&gt;
(23 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;
2&amp;gt;&lt;br /&gt;
3&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Summarizing Data with CUBE==&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;
WITH CUBE summarizes total values based on the columns in the GROUP BY clause.&lt;br /&gt;
Extra NULL values were included in the result set for those rows that contained the WITH CUBE aggregate totals.&lt;br /&gt;
15&amp;gt; CREATE TABLE employee(&lt;br /&gt;
16&amp;gt;    id          INTEGER NOT NULL PRIMARY KEY,&lt;br /&gt;
17&amp;gt;    first_name  VARCHAR(10),&lt;br /&gt;
18&amp;gt;    last_name   VARCHAR(10),&lt;br /&gt;
19&amp;gt;    salary      DECIMAL(10,2),&lt;br /&gt;
20&amp;gt;    start_Date  DATETIME,&lt;br /&gt;
21&amp;gt;    region      VARCHAR(10),&lt;br /&gt;
22&amp;gt;    city        VARCHAR(20),&lt;br /&gt;
23&amp;gt;    managerid   INTEGER&lt;br /&gt;
24&amp;gt; );&lt;br /&gt;
25&amp;gt; GO&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (1, &amp;quot;Jason&amp;quot; ,  &amp;quot;Martin&amp;quot;, 5890,&amp;quot;2005-03-22&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Vancouver&amp;quot;,3);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (2, &amp;quot;Alison&amp;quot;,  &amp;quot;Mathews&amp;quot;,4789,&amp;quot;2003-07-21&amp;quot;,&amp;quot;South&amp;quot;,&amp;quot;Utown&amp;quot;,4);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (3, &amp;quot;James&amp;quot; ,  &amp;quot;Smith&amp;quot;,  6678,&amp;quot;2001-12-01&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Paris&amp;quot;,5);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (4, &amp;quot;Celia&amp;quot; ,  &amp;quot;Rice&amp;quot;,   5567,&amp;quot;2006-03-03&amp;quot;,&amp;quot;South&amp;quot;,&amp;quot;London&amp;quot;,6);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (5, &amp;quot;Robert&amp;quot;,  &amp;quot;Black&amp;quot;,  4467,&amp;quot;2004-07-02&amp;quot;,&amp;quot;East&amp;quot;,&amp;quot;Newton&amp;quot;,7);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (6, &amp;quot;Linda&amp;quot; ,  &amp;quot;Green&amp;quot; , 6456,&amp;quot;2002-05-19&amp;quot;,&amp;quot;East&amp;quot;,&amp;quot;Calgary&amp;quot;,8);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (7, &amp;quot;David&amp;quot; ,  &amp;quot;Larry&amp;quot;,  5345,&amp;quot;2008-03-18&amp;quot;,&amp;quot;West&amp;quot;,&amp;quot;New York&amp;quot;,9);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (8, &amp;quot;James&amp;quot; ,  &amp;quot;Cat&amp;quot;,    4234,&amp;quot;2007-07-17&amp;quot;,&amp;quot;West&amp;quot;,&amp;quot;Regina&amp;quot;,9);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (9, &amp;quot;Joan&amp;quot;  ,  &amp;quot;Act&amp;quot;,    6123,&amp;quot;2001-04-16&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Toronto&amp;quot;,10);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; select * from employee;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
id          first_name last_name  salary       start_Date              region     city                 managerid&lt;br /&gt;
----------- ---------- ---------- ------------ ----------------------- ---------- -------------------- -----------&lt;br /&gt;
          1 Jason      Martin          5890.00 2005-03-22 00:00:00.000 North      Vancouver                      3&lt;br /&gt;
          2 Alison     Mathews         4789.00 2003-07-21 00:00:00.000 South      Utown                          4&lt;br /&gt;
          3 James      Smith           6678.00 2001-12-01 00:00:00.000 North      Paris                          5&lt;br /&gt;
          4 Celia      Rice            5567.00 2006-03-03 00:00:00.000 South      London                         6&lt;br /&gt;
          5 Robert     Black           4467.00 2004-07-02 00:00:00.000 East       Newton                         7&lt;br /&gt;
          6 Linda      Green           6456.00 2002-05-19 00:00:00.000 East       Calgary                        8&lt;br /&gt;
          7 David      Larry           5345.00 2008-03-18 00:00:00.000 West       New York                       9&lt;br /&gt;
          8 James      Cat             4234.00 2007-07-17 00:00:00.000 West       Regina                         9&lt;br /&gt;
          9 Joan       Act             6123.00 2001-04-16 00:00:00.000 North      Toronto                       10&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; SELECT i.region,SUM(i.salary) Total&lt;br /&gt;
4&amp;gt; FROM employee i&lt;br /&gt;
5&amp;gt; GROUP BY i.region&lt;br /&gt;
6&amp;gt; WITH CUBE;&lt;br /&gt;
7&amp;gt; GO&lt;br /&gt;
region     Total&lt;br /&gt;
---------- ----------------------------------------&lt;br /&gt;
East                                       10923.00&lt;br /&gt;
North                                      18691.00&lt;br /&gt;
South                                      10356.00&lt;br /&gt;
West                                        9579.00&lt;br /&gt;
NULL                                       49549.00&lt;br /&gt;
(5 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt;&lt;br /&gt;
5&amp;gt; drop table employee;&lt;br /&gt;
6&amp;gt; GO&lt;br /&gt;
1&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Using GROUPING with CUBE==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
5&amp;gt; CREATE TABLE employee(&lt;br /&gt;
6&amp;gt;    id          INTEGER NOT NULL PRIMARY KEY,&lt;br /&gt;
7&amp;gt;    first_name  VARCHAR(10),&lt;br /&gt;
8&amp;gt;    last_name   VARCHAR(10),&lt;br /&gt;
9&amp;gt;    salary      DECIMAL(10,2),&lt;br /&gt;
10&amp;gt;    start_Date  DATETIME,&lt;br /&gt;
11&amp;gt;    region      VARCHAR(10),&lt;br /&gt;
12&amp;gt;    city        VARCHAR(20),&lt;br /&gt;
13&amp;gt;    managerid   INTEGER&lt;br /&gt;
14&amp;gt; );&lt;br /&gt;
15&amp;gt; GO&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (1, &amp;quot;Jason&amp;quot; ,  &amp;quot;Martin&amp;quot;, 5890,&amp;quot;2005-03-22&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Vancouver&amp;quot;,3);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (2, &amp;quot;Alison&amp;quot;,  &amp;quot;Mathews&amp;quot;,4789,&amp;quot;2003-07-21&amp;quot;,&amp;quot;South&amp;quot;,&amp;quot;Utown&amp;quot;,4);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (3, &amp;quot;James&amp;quot; ,  &amp;quot;Smith&amp;quot;,  6678,&amp;quot;2001-12-01&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Paris&amp;quot;,5);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (4, &amp;quot;Celia&amp;quot; ,  &amp;quot;Rice&amp;quot;,   5567,&amp;quot;2006-03-03&amp;quot;,&amp;quot;South&amp;quot;,&amp;quot;London&amp;quot;,6);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (5, &amp;quot;Robert&amp;quot;,  &amp;quot;Black&amp;quot;,  4467,&amp;quot;2004-07-02&amp;quot;,&amp;quot;East&amp;quot;,&amp;quot;Newton&amp;quot;,7);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (6, &amp;quot;Linda&amp;quot; ,  &amp;quot;Green&amp;quot; , 6456,&amp;quot;2002-05-19&amp;quot;,&amp;quot;East&amp;quot;,&amp;quot;Calgary&amp;quot;,8);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (7, &amp;quot;David&amp;quot; ,  &amp;quot;Larry&amp;quot;,  5345,&amp;quot;2008-03-18&amp;quot;,&amp;quot;West&amp;quot;,&amp;quot;New York&amp;quot;,9);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (8, &amp;quot;James&amp;quot; ,  &amp;quot;Cat&amp;quot;,    4234,&amp;quot;2007-07-17&amp;quot;,&amp;quot;West&amp;quot;,&amp;quot;Regina&amp;quot;,9);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO employee VALUES (9, &amp;quot;Joan&amp;quot;  ,  &amp;quot;Act&amp;quot;,    6123,&amp;quot;2001-04-16&amp;quot;,&amp;quot;North&amp;quot;,&amp;quot;Toronto&amp;quot;,10);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; select * from employee;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
id          first_name last_name  salary       start_Date              region     city                 managerid&lt;br /&gt;
----------- ---------- ---------- ------------ ----------------------- ---------- -------------------- -----------&lt;br /&gt;
          1 Jason      Martin          5890.00 2005-03-22 00:00:00.000 North      Vancouver                      3&lt;br /&gt;
          2 Alison     Mathews         4789.00 2003-07-21 00:00:00.000 South      Utown                          4&lt;br /&gt;
          3 James      Smith           6678.00 2001-12-01 00:00:00.000 North      Paris                          5&lt;br /&gt;
          4 Celia      Rice            5567.00 2006-03-03 00:00:00.000 South      London                         6&lt;br /&gt;
          5 Robert     Black           4467.00 2004-07-02 00:00:00.000 East       Newton                         7&lt;br /&gt;
          6 Linda      Green           6456.00 2002-05-19 00:00:00.000 East       Calgary                        8&lt;br /&gt;
          7 David      Larry           5345.00 2008-03-18 00:00:00.000 West       New York                       9&lt;br /&gt;
          8 James      Cat             4234.00 2007-07-17 00:00:00.000 West       Regina                         9&lt;br /&gt;
          9 Joan       Act             6123.00 2001-04-16 00:00:00.000 North      Toronto                       10&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; SELECT i.region, GROUPING(i.region) Source,&lt;br /&gt;
4&amp;gt; SUM(i.salary) Total&lt;br /&gt;
5&amp;gt; FROM employee i&lt;br /&gt;
6&amp;gt; GROUP BY i.region&lt;br /&gt;
7&amp;gt; WITH CUBE;&lt;br /&gt;
8&amp;gt; GO&lt;br /&gt;
region     Source Total&lt;br /&gt;
---------- ------ ----------------------------------------&lt;br /&gt;
East            0                                 10923.00&lt;br /&gt;
North           0                                 18691.00&lt;br /&gt;
South           0                                 10356.00&lt;br /&gt;
West            0                                  9579.00&lt;br /&gt;
NULL            1                                 49549.00&lt;br /&gt;
(5 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;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Using the CUBE Operator==&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;
CUBE with GROUP BY calculates aggregate function on all records and appends this to the last row&lt;br /&gt;
&lt;br /&gt;
10&amp;gt; CREATE TABLE Classification (&lt;br /&gt;
11&amp;gt;      Classif_ID         integer  NOT NULL PRIMARY KEY,&lt;br /&gt;
12&amp;gt;      Classification    varchar(25))&lt;br /&gt;
13&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; INSERT into Classification VALUES( 1,&amp;quot;Pop&amp;quot;)&lt;br /&gt;
3&amp;gt; INSERT into Classification VALUES( 2,&amp;quot;Country&amp;quot;)&lt;br /&gt;
4&amp;gt; INSERT into Classification VALUES( 3,&amp;quot;Alternative&amp;quot;)&lt;br /&gt;
5&amp;gt; INSERT into Classification VALUES( 4,&amp;quot;Metal&amp;quot;)&lt;br /&gt;
6&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; CREATE TABLE CD (&lt;br /&gt;
4&amp;gt;      CD_ID              integer  NOT NULL PRIMARY KEY,&lt;br /&gt;
5&amp;gt;      CD_Title           varchar(40),&lt;br /&gt;
6&amp;gt;      Composer_ID        integer  NOT NULL,&lt;br /&gt;
7&amp;gt;      Classif_ID         integer  NOT NULL,&lt;br /&gt;
8&amp;gt;      SalesPrice        money,&lt;br /&gt;
9&amp;gt;      AverageCost       money)&lt;br /&gt;
10&amp;gt; GO&lt;br /&gt;
1&amp;gt; INSERT into CD VALUES(2000,&amp;quot;John&amp;quot;,100,1,16.99,6.99)&lt;br /&gt;
2&amp;gt; INSERT into CD VALUES(2001,&amp;quot;Chicago 16&amp;quot;,107,1,14.99,5.99)&lt;br /&gt;
3&amp;gt; INSERT into CD VALUES(2002,&amp;quot;Chicago 17&amp;quot;,107,1,14.99,5.99)&lt;br /&gt;
4&amp;gt; INSERT into CD VALUES(2003,&amp;quot;Chicago 18&amp;quot;,107,1,14.99,5.99)&lt;br /&gt;
5&amp;gt; INSERT into CD VALUES(2004,&amp;quot;Greatest Hits&amp;quot;,107,1,16.99,7.99)&lt;br /&gt;
6&amp;gt; INSERT into CD VALUES(2005,&amp;quot;Midnight&amp;quot;,101,3,14.99,5.99)&lt;br /&gt;
7&amp;gt; INSERT into CD VALUES(2006,&amp;quot;Mode&amp;quot;,115,3,14.99,5.99)&lt;br /&gt;
8&amp;gt; INSERT into CD VALUES(2007,&amp;quot;Ultra&amp;quot;,115,3,15.99,5.99)&lt;br /&gt;
9&amp;gt; INSERT into CD VALUES(2008,&amp;quot;Mindcrime&amp;quot;,102,4,14.99,5.99)&lt;br /&gt;
10&amp;gt; INSERT into CD VALUES(2009,&amp;quot;Empire&amp;quot;,102,4,14.99,5.99)&lt;br /&gt;
11&amp;gt; INSERT into CD VALUES(2010,&amp;quot;Land&amp;quot;,102,4,12.99,4.99)&lt;br /&gt;
12&amp;gt; INSERT into CD VALUES(2011,&amp;quot;Night&amp;quot;,103,4,11.99,3.99)&lt;br /&gt;
13&amp;gt; INSERT into CD VALUES(2012,&amp;quot;Pyromania&amp;quot;,103,4,14.99,5.99)&lt;br /&gt;
14&amp;gt; INSERT into CD VALUES(2013,&amp;quot;Hysteria&amp;quot;,103,4,14.99,5.99)&lt;br /&gt;
15&amp;gt; INSERT into CD VALUES(2014,&amp;quot;Hits&amp;quot;,103,4,13.99,4.99)&lt;br /&gt;
16&amp;gt; INSERT into CD VALUES(2015,&amp;quot;Hits 2&amp;quot;,104,2,15.99,6.99)&lt;br /&gt;
17&amp;gt; INSERT into CD VALUES(2016,&amp;quot;Greatest&amp;quot;,105,2,14.99,5.99)&lt;br /&gt;
18&amp;gt; INSERT into CD VALUES(2017,&amp;quot;Hits 3&amp;quot;,106,1,13.99,5.99)&lt;br /&gt;
19&amp;gt; INSERT into CD VALUES(2018,&amp;quot;Deep&amp;quot;,108,1,12.99,2.99)&lt;br /&gt;
20&amp;gt; INSERT into CD VALUES(2019,&amp;quot;Turning&amp;quot;,109,1,14.99,5.99)&lt;br /&gt;
21&amp;gt; INSERT into CD VALUES(2020,&amp;quot;TheHits&amp;quot;,109,1,16.99,7.99)&lt;br /&gt;
22&amp;gt; INSERT into CD VALUES(2021,&amp;quot;Cars&amp;quot;,110,1,9.99,3.99)&lt;br /&gt;
23&amp;gt; INSERT into CD VALUES(2022,&amp;quot;Anthology&amp;quot;,110,1,25.99,11.99)&lt;br /&gt;
24&amp;gt; INSERT into CD VALUES(2023,&amp;quot;City&amp;quot;,110,1,14.99,5.99)&lt;br /&gt;
25&amp;gt; INSERT into CD VALUES(2024,&amp;quot;Rick&amp;quot;,111,1,11.99,2.99)&lt;br /&gt;
26&amp;gt; INSERT into CD VALUES(2025,&amp;quot;Live&amp;quot;,112,1,19.99,8.99)&lt;br /&gt;
27&amp;gt; INSERT into CD VALUES(2026,&amp;quot;Pat&amp;quot;,113,1,16.99,6.99)&lt;br /&gt;
28&amp;gt; INSERT into CD VALUES(2027,&amp;quot;Big&amp;quot;,114,1,14.99,5.99)&lt;br /&gt;
29&amp;gt; INSERT into CD VALUES(2028,&amp;quot;Hurting&amp;quot;,114,1,11.99,3.99)&lt;br /&gt;
30&amp;gt; INSERT into CD VALUES(2029,&amp;quot;Vol 1&amp;quot;,116,1,9.99,2.99)&lt;br /&gt;
31&amp;gt; INSERT into CD VALUES(2030,&amp;quot;Vol 2&amp;quot;,116,1,9.99,2.99)&lt;br /&gt;
32&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 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 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;&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt; SELECT Classification.Classification,&lt;br /&gt;
5&amp;gt;        Count(CD.CD_ID) &amp;quot;Total Offerings&amp;quot;&lt;br /&gt;
6&amp;gt; FROM CD,Classification&lt;br /&gt;
7&amp;gt; WHERE CD.Classif_ID = Classification.Classif_ID&lt;br /&gt;
8&amp;gt; GROUP BY Classification.Classification with CUBE&lt;br /&gt;
9&amp;gt; GO&lt;br /&gt;
Classification            Total Offerings&lt;br /&gt;
------------------------- ---------------&lt;br /&gt;
Alternative                             3&lt;br /&gt;
Country                                 2&lt;br /&gt;
Metal                                   7&lt;br /&gt;
Pop                                    19&lt;br /&gt;
NULL                                   31&lt;br /&gt;
(5 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table Classification;&lt;br /&gt;
3&amp;gt; drop table CD;&lt;br /&gt;
4&amp;gt; GO&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>