日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
Oracle實現(xiàn)分組統(tǒng)計記錄

今天剛上班不久,QQ滴滴的響個不停,看了下信息是一個網(wǎng)友要我?guī)兔ο乱粋€SQL語句,大體意思是:統(tǒng)計heart_active字段為不同情況的記錄數(shù),然后按時間來分組。

   我想了下,心里想這好辦,于是馬上建了一個表,語句如下:

 
 
 
 
  1. CREATE TABLE rfid_fixed_heart (input_date date,heart_active   VARCHAR2(2)); 

    接下來往rfid_fixed_heart表中插入了數(shù)據(jù),heart_active字段為0和1, input_date中插入YYYY-MM-DD格式的數(shù)據(jù)。

后來就寫了下面兩個SQL給她,語句一和語句二有點區(qū)別,語句一快一統(tǒng)計出heart_active字段為不同情況的記錄數(shù),而語句二則只統(tǒng)計heart_active字段為0和1情況的記錄數(shù),兩個語句的輸出格式也有不同。具體如下:

語句一:

 
 
 
 
  1. SELECT a.input_date, a.heart_active, SUM(decode(a.heart_active, 1, 1, 0, 1))  
  2.  FROM rfid_fixed_heart a  
  3.  GROUP BY a.heart_active, a.input_date  
  4.  ORDER BY a.input_date DESC; 

 

語句二:

 
 
 
 
  1. SELECT a.input_date, SUM(decode(a.heart_active, '0', '1')) AS heart_active_0,SUM(decode(a.heart_active, '1', '1')) AS heart_active_1  
  2.  FROM rfid_fixed_heart a  
  3.  GROUP BY a.input_date;   
  4.  

很快就反饋過結(jié)果來了,沒有達(dá)到預(yù)期的效果,但從她的結(jié)果可以看出是由于input_date插入的是YYYY-MM-DD 24HH:MI:SS格式的數(shù)據(jù)導(dǎo)致無法按日期來分組。

既然插入的是YYYY-MM-DD 24HH:MI:SS格式得數(shù)據(jù),要按日期來排序就需要對input_date使用trunc函數(shù)來截取日期值。

最終把原來的兩個SQL改成如下語句:

語句三:

 
 
 
 
  1. SELECT trunc(a.input_date, 'dd'), a.heart_active, SUM(decode(a.heart_active, 1, 1, 0, 1))  
  2.  
  3.       FROM rfid_fixed_heart a  
  4.  
  5.  GROUP BY a.heart_active, trunc(a.input_date, 'dd')  
  6.  
  7.  ORDER BY trunc(a.input_date, 'dd') DESC;  
  8.  

語句四:

 
 
 
 
  1. SELECT trunc(a.input_date, 'dd'), SUM(decode(a.heart_active, '0', '1')) AS heart_active_0,  
  2.  
  3.                    SUM(decode(a.heart_active, '1', '1')) AS heart_active_1  
  4.  
  5.       FROM rfid_fixed_heart a  
  6.  
  7.  GROUP BY trunc(a.input_date, 'dd');   
  8.  

把語句給那網(wǎng)友后,運行滿足要求,OK。對于SQL語句的編寫需要認(rèn)真考慮數(shù)據(jù)特殊性和表結(jié)構(gòu),那樣才能夠?qū)崿F(xiàn)SQL語句對不同環(huán)境的適用。

   附未使用decode函數(shù)的實現(xiàn)SQL:

 
 
 
 
  1. SELECT op_date, heart_active, SUM(heart_active_0) AS heart_active_0,  
  2.  
  3.                    SUM(heart_active_1) AS heart_active_1  
  4.  
  5.       FROM (SELECT to_char(rfid_fixed_heart.input_date, 'yyyy-mm-dd') AS op_date,  
  6.  
  7.                                                 heart_active AS heart_active,  
  8.  
  9.                                                 CASE heart_active  
  10.  
  11.                                                              WHEN '0' THEN 
  12.  
  13.                                                                   COUNT(heart_active)  
  14.  
  15.                                                              ELSE 
  16.  
  17.                                                                   0  
  18.  
  19.                                                  END AS heart_active_0,  
  20.  
  21.                                                 CASE heart_active  
  22.  
  23.                                                              WHEN '1' THEN 
  24.  
  25.                                                                   COUNT(heart_active)  
  26.  
  27.                                                              ELSE 
  28.  
  29.                                                                   0  
  30.  
  31.                                                  END AS heart_active_1  
  32.  
  33.                                FROM rfid_fixed_heart  
  34.  
  35.                               GROUP BY input_date, heart_active) a  
  36.  
  37.  GROUP BY op_date, heart_active  
  38.  
  39.  ORDER BY op_date DESC 
  40.  

結(jié)果如下:


本文標(biāo)題:Oracle實現(xiàn)分組統(tǒng)計記錄
本文鏈接:http://www.dlmjj.cn/article/cdjjdpe.html