日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

oracle分组汇总人数,Oracle实现分组统计记录

發布時間:2025/3/19 编程问答 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 oracle分组汇总人数,Oracle实现分组统计记录 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

今天剛上班不久,QQ滴滴的響個不停,看了下信息是一個網友要我幫忙下一個SQL語句,大體意思是:統計heart_active字段為不同情況的記錄數,然后按時間來分組。

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

CREATETABLErfid_fixed_heart?(input_datedate,heart_active???VARCHAR2(2));

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

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

語句一:

SELECTa.input_date,?a.heart_active,SUM(decode(a.heart_active,?1,?1,?0,?1))

FROMrfid_fixed_heart?a

GROUPBYa.heart_active,?a.input_date

ORDERBYa.input_dateDESC;

語句二:

SELECTa.input_date,SUM(decode(a.heart_active,'0','1'))ASheart_active_0,SUM(decode(a.heart_active,'1','1'))ASheart_active_1

FROMrfid_fixed_heart?a

GROUPBYa.input_date;

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

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

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

語句三:

SELECTtrunc(a.input_date,'dd'),?a.heart_active,SUM(decode(a.heart_active,?1,?1,?0,?1))

FROMrfid_fixed_heart?a

GROUPBYa.heart_active,?trunc(a.input_date,'dd')

ORDERBYtrunc(a.input_date,'dd')DESC;

語句四:

SELECTtrunc(a.input_date,'dd'),SUM(decode(a.heart_active,'0','1'))ASheart_active_0,

SUM(decode(a.heart_active,'1','1'))ASheart_active_1

FROMrfid_fixed_heart?a

GROUPBYtrunc(a.input_date,'dd');

把語句給那網友后,運行滿足要求,OK。對于SQL語句的編寫需要認真考慮數據特殊性和表結構,那樣才能夠實現SQL語句對不同環境的適用。

附未使用decode函數的實現SQL:

SELECTop_date,?heart_active,SUM(heart_active_0)ASheart_active_0,

SUM(heart_active_1)ASheart_active_1

FROM(SELECTto_char(rfid_fixed_heart.input_date,'yyyy-mm-dd')ASop_date,

heart_activeASheart_active,

CASEheart_active

WHEN'0'THEN

COUNT(heart_active)

ELSE

0

ENDASheart_active_0,

CASEheart_active

WHEN'1'THEN

COUNT(heart_active)

ELSE

0

ENDASheart_active_1

FROMrfid_fixed_heart

GROUPBYinput_date,?heart_active)?a

GROUPBYop_date,?heart_active

ORDERBYop_dateDESC

結果如下:

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

【編輯推薦】

【責任編輯:艾婧 TEL:(010)68476606】

點贊 0

與50位技術專家面對面20年技術見證,附贈技術全景圖

總結

以上是生活随笔為你收集整理的oracle分组汇总人数,Oracle实现分组统计记录的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。