自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Oracle數(shù)據(jù)庫中如何用GROUPING SETS進行分組自定義

數(shù)據(jù)庫 Oracle
我們今天跟大家講述的是Oracle GROUPING SETS進行分組自定義的匯總,以下就是文章的詳細內(nèi)容的描述。望你會有所收獲。

以下的文章主要介紹的實施在Oracle GROUPING SETS進行分組自定義的匯總,本文章主要是通過作者在實際操作中的經(jīng)驗,來講述在Oracle數(shù)據(jù)庫中正確使用GROUPING SETS分組自定義。

當你與COUNT和SUM這類總計函數(shù)一起使用GROUP BY語句時,你一般得不到多級總數(shù)。GROUP BY中每個唯一的列組合生成一個總數(shù),但這些總數(shù)不會“累加”到更高一級的總數(shù)中。

要實現(xiàn)這一點,你可以用GROUP BY ROLLUP或GROUP BY CUBE替代GROUP BY,不過它們會生成所有可能的總數(shù),而你可能不需要全部總數(shù)。對GROUP BY CUBE而言,將會生成2^n組總數(shù),這里的n是GROUP BY中列的數(shù)目。

查看下面的查詢,它使用了SH樣本模式:

  1. SELECT prod_id, cust_id, channel_id, SUM(quantity_sold)  
  2. FROM sales  
  3. WHERE cust_id < 3 
  4. GROUP BY CUBE (prod_id, cust_id, channel_id) 

這將生成8組總數(shù):

所有行的總和

每個通道,包括所有產(chǎn)品和顧客。

每個顧客,包括所有產(chǎn)品和通道。

每項產(chǎn)品,包括所有顧客和通道。

每個通道/顧客組合,包括所有產(chǎn)品。

每個通道/產(chǎn)品組合,包括所有顧客。

每個產(chǎn)品/顧客組合,包括所有通道。

每個產(chǎn)品、顧客和通道組合。

可能的組合非常多。GROUP BY CUBE中每增加一列,生成的總數(shù)就會翻一番。

可以用GROUP BY GROUPING SETS來代替GROUP BY CUBE。你可以應用來指定你感興趣的總數(shù)組合。因為它不必計算它不需要集合(也不會產(chǎn)生太多結(jié)果),所以對SQL引擎來說更為高效。

其格式為:

  1. GROUP BY GROUPING SETS ((list), (list) ... ) 

這里(list)是圓括號中的一個列序列,這個組合生成一個總數(shù)。要增加一個總和,必須增加一個(NUlL)分組集。

例如,如果只要生成每項產(chǎn)品(包括所有顧客和通道)和每個顧客/通道組合(包括所有產(chǎn)品)的總數(shù),可以輸入:

  1. SELECT prod_id, cust_id, channel_id, SUM(quantity_sold)  
  2. FROM sales  
  3. WHERE cust_id < 3 
  4. GROUP BY GROUPING SETS (  
  5. (prod_id), (cust_id, channel_id)  
  6. ); 

這種方法將這個數(shù)據(jù)集生成的總數(shù)數(shù)量從180個減少到37個,并幫助你著重回答你希望解答的問題。以上的相關內(nèi)容就是對Oracle GROUPING SETS進行分組自定義的匯總的介紹,望你能有所收獲。
 

【編輯推薦】

  1. 實現(xiàn)異地Oracle數(shù)據(jù)庫的數(shù)據(jù)同步步驟
  2. Oracle分頁查詢語句的實際應用
  3. Oracle修改相關字段的幾種常用方法
  4. Oracle字符集中的一些問題總結(jié)
  5. Oracle企業(yè)管理器11g獲合作伙伴青睞的原因

 

責任編輯:佚名 來源: 博客園
相關推薦

2011-07-18 14:00:29

RailsOracle

2010-06-29 17:27:14

SQL Server

2024-01-05 15:28:06

鴻蒙數(shù)據(jù)同步GlobalThis

2014-06-10 15:07:19

Oracle數(shù)據(jù)庫優(yōu)化

2010-06-28 11:00:46

SQL Server

2010-07-09 14:30:56

SQL Server

2012-05-10 11:34:04

Windows數(shù)據(jù)庫

2023-09-05 08:40:57

刪除數(shù)據(jù)庫Oracle

2010-03-01 11:10:41

WCF綁定元素

2010-10-25 16:05:07

oracle自定義函數(shù)

2010-04-28 12:33:36

Oracle自定義函數(shù)

2011-03-22 14:49:35

Oracle數(shù)據(jù)庫重定義表

2022-04-11 07:47:45

zabbix郵件告警項目

2022-09-07 15:57:41

KubernetesCRD

2010-04-19 13:15:00

Oracle數(shù)據(jù)庫

2019-11-19 08:04:16

JavaHashSet去重

2010-05-05 15:45:52

Oracle數(shù)據(jù)庫

2009-08-03 16:37:49

C#異常類

2010-04-19 16:01:54

2018-03-16 08:41:16

Oracle存儲函數(shù)
點贊
收藏

51CTO技術(shù)棧公眾號