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

Oracle實(shí)現(xiàn)分組統(tǒng)計(jì)記錄

數(shù)據(jù)庫(kù) Oracle
筆者根據(jù)網(wǎng)友提出的“統(tǒng)計(jì)heart_active字段為不同情況的記錄數(shù),然后按時(shí)間來(lái)分組”的要求,編寫(xiě)出了相應(yīng)語(yǔ)句來(lái)解答這一問(wèn)題。

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

   我想了下,心里想這好辦,于是馬上建了一個(gè)表,語(yǔ)句如下:

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

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

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

語(yǔ)句一:

  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

 

語(yǔ)句二:

  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.  

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

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

最終把原來(lái)的兩個(gè)SQL改成如下語(yǔ)句:

語(yǔ)句三:

  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.  

語(yǔ)句四:

  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.  

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

   附未使用decode函數(shù)的實(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é)果如下:

 

原文鏈接:http://www.cnblogs.com/Automation_software/archive/2011/03/02/1968737.html

【編輯推薦】

  1. 詳解oracle事務(wù)隔離級(jí)別
  2. 淺析Oracle多語(yǔ)言環(huán)境下to_date時(shí)間轉(zhuǎn)換
  3. Oracle數(shù)據(jù)集成的實(shí)際解決方案
  4. Oracle數(shù)據(jù)庫(kù)中兩個(gè)易被忽視的進(jìn)程  
責(zé)任編輯:艾婧 來(lái)源: 博客園
相關(guān)推薦

2010-10-27 16:49:23

Oracle刪除重復(fù)記

2010-11-15 14:07:16

Oracle取固定記錄

2009-06-15 17:45:20

LINQ分組統(tǒng)計(jì)

2010-11-15 13:47:13

oracle記錄加鎖

2010-11-15 13:35:28

Oracle記錄類(lèi)型

2010-09-26 15:15:11

SQL語(yǔ)句

2009-03-24 13:04:55

匯總組織結(jié)構(gòu)Oracle

2010-10-28 17:08:11

Oracle查詢(xún)

2010-10-25 17:13:08

oracle分組函數(shù)

2010-11-15 15:06:58

ORACLE數(shù)據(jù)庫(kù)記錄

2024-11-27 09:32:58

2010-04-13 11:35:26

Oracle字符集

2011-04-12 09:20:28

OracleDBLINK

2010-11-15 14:16:09

Oracle表記錄

2021-09-12 07:26:49

MySQL SQL 語(yǔ)句數(shù)據(jù)庫(kù)

2010-04-20 13:17:44

2009-04-08 10:20:43

Oracle插入查詢(xún)

2010-10-27 16:56:05

Oracle重復(fù)記錄

2015-07-15 10:37:10

IOS用戶行為統(tǒng)計(jì)代碼

2010-05-07 15:23:52

Oracle系統(tǒng)性能
點(diǎn)贊
收藏

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