校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > PostgreSQL完成按月累加的操作

PostgreSQL完成按月累加的操作

熱門標簽:電銷機器人能補救房產中介嗎 廣州電銷機器人公司招聘 400電話申請客服 地圖標注要花多少錢 移動外呼系統模擬題 電話機器人怎么換人工座席 濟南外呼網絡電話線路 江蘇400電話辦理官方 天津開發區地圖標注app

背景

統計某個指標,指標按照月進行累加,注意需要按省份和年份進行分組。

方法一、使用自關聯

-- with 按月統計得到中間結果
WITH yms AS (SELECT regionid,SUM(getnum) AS getnum,SUM(dealnum) AS dealnum,to_char(qndate,'yyyy-MM') AS yearmonth
FROM t_queuenumber
GROUP BY regionid,to_char(qndate,'yyyy-MM')
ORDER BY regionid,yearmonth)-- 查用子查詢解決。
SELECT s1.regionid,s1.yearmonth, getnum,dealnum,
(SELECT SUM(getnum) FROM yms s2 WHERE s2.regionid = s1.regionid AND s2.yearmonth = s1.yearmonth AND SUBSTRING(s1.yearmonth,0,5) = SUBSTRING(s2.yearmonth,0,5) ) AS getaccumulatednum,
(SELECT SUM(dealnum) FROM yms s2 WHERE s2.regionid = s1.regionid AND s2.yearmonth = s1.yearmonth AND SUBSTRING(s1.yearmonth,0,5) = SUBSTRING(s2.yearmonth,0,5) ) AS accumulatednum
FROM yms s1;

查詢的結果如下:

方法二、使用窗口函數

更多關于窗口函數的用法,可以參考以前的文章。窗口函數十分適合這樣的場景:

 WITH yms AS (SELECT regionid,SUM(getnum) AS getnum,SUM(dealnum) AS dealnum,to_char(qndate,'yyyy-MM') AS yearmonth
 FROM t_queuenumber
 GROUP BY regionid,to_char(qndate,'yyyy-MM')
 ORDER BY regionid,yearmonth)
 -- 窗口函數的使用
 SELECT regionid,yearmonth,
 SUM(getnum) OVER(PARTITION BY regionid,SUBSTRING(yearmonth,0,5) ORDER BY yearmonth) AS getaccumulatednum,
 SUM(dealnum) OVER(PARTITION BY regionid ,SUBSTRING(yearmonth,0,5) ORDER BY yearmonth) AS dealaccumulatednum
 FROM yms; 

后記

可以使用子查詢、可以使用窗口函數完成上面業務場景。

補充:PostgreSQL實現按秒按分按時按日按周按月按年統計數據

提取時間(年月日時分秒):

import datetime
from dateutil.relativedelta import relativedelta
today = str(datetime.datetime.now())
print(today)
print(today[:4], today[:7], today[:10],today[:13])
 
print("************分隔符***************")
 
yesterday = (datetime.datetime.now() + datetime.timedelta(days=-1)).strftime("%Y-%m-%d %H:%M:%S")
yesterday2 = (datetime.datetime.now() + datetime.timedelta(days=-2)).strftime("%Y-%m-%d %H:%M:%S")
nextmonths = str(datetime.date.today() - relativedelta(months=-1))[:7]
lastmonths = str(datetime.date.today() - relativedelta(months=+1))[:7]
lastyears = str(datetime.date.today() - relativedelta(years=+1))[:4]
nextyears = str(datetime.date.today() - relativedelta(years=-1))[:4]
 
print(yesterday)
print(yesterday2)
print(nextmonths)
print(lastmonths)
print(lastyears)
print(nextyears)

結果:

2020-03-05 13:49:59.982555
2020 2020-03 2020-03-05 2020-03-05 13
************分隔符***************
2020-03-04 13:49:59
2020-03-03 13:49:59
2020-04
2020-02
2019
2021

昨日每時:

select s.acceptDate, s.data_num
 from (select to_char(acceptDate, 'yyyy-mm-dd hh24') || '點' as acceptDate,
        count(1) as data_num
     from table_name t
     where t.acceptDate >= to_date('20190506', 'yyyymmdd')
      and t.acceptDate  to_date('20190507', 'yyyymmdd') and organization_ = 'abcdefghijklmnopqrstuvwxyz' 
     group by to_char(acceptDate, 'yyyy-mm-dd hh24') || '點') s

本月每天:

select s.acceptDate, s.data_num
 from (select to_char(acceptDate, 'yyyy-mm-dd') as acceptDate,
        count(1) as data_num
     from table_name t
     where t.acceptDate >= to_date('201905', 'yyyymm')
      and t.acceptDate  to_date('201906', 'yyyymm') and organization_ = 'abcdefghijklmnopqrstuvwxyz' 
     group by to_char(acceptDate, 'yyyy-mm-dd') ) s

本年每月:

select s.acceptDate, s.data_num
 from (select to_char(acceptDate, 'yyyy-mm') as acceptDate,
        count(1) as data_num
     from table_name t
     where t.acceptDate >= to_date('2019', 'yyyy')
      and t.acceptDate  to_date('2020', 'yyyy') and organization_ = 'abcdefghijklmnopqrstuvwxyz' 
     group by to_char(acceptDate, 'yyyy-mm') ) s

2月-7月中每月的人數統計:

sql = """SELECT to_char(rujiaoriqi, 'yyyy-mm') as month,count(1) num 
           FROM jibenxx where rujiaoriqi is not null and zhongzhiriqi is null 
           AND to_char(rujiaoriqi,'yyyy-mm-dd')>='2020-02-01'
           GROUP BY to_char(rujiaoriqi, 'yyyy-mm') order by to_char(rujiaoriqi, 'yyyy-mm') """

統計每年:

select s.acceptDate, s.data_num
 from (select to_char(acceptDate, 'yyyy') as acceptDate,
        count(1) as data_num
     from table_name t
     where t.acceptDate >= to_date('2015', 'yyyy')
      and t.acceptDate  to_date('2021', 'yyyy') and organization_ = 'abcdefghijklmnopqrstuvwxyz' 
     group by to_char(acceptDate, 'yyyy') ) s

里面時間參數進行傳參即可。

補充:

統計今天(查詢當天或者指定某天數量)

select count(1) FROM "shequjz_jibenxx" where to_char(zhongzhiriqi,'yyyy-mm-dd')='2019-11-11' 

最近七天每天的數量:

select s.acceptDate, s.data_num
 from (select to_char(jiaozheng_jieshushijian, 'yyyy-mm-dd') as acceptDate,
        count(1) as data_num
     from shequjz_jibenxx t
     where t.jiaozheng_jieshushijian >= to_date('2020-11-06', 'yyyy-mm-dd')
      and t.jiaozheng_jieshushijian  to_date('2020-11-13', 'yyyy-mm-dd') 
     group by to_char(jiaozheng_jieshushijian, 'yyyy-mm-dd') ) s ORDER BY acceptDate ASC

最近七天(1天、3天、7天、一個月、一年、1h、1min、60s)的數量(總量):

# 包括今天向前推6天的總量
select count(1) from shequjz_jibenxx where jiaozheng_jieshushijian 
between (SELECT current_timestamp - interval '7 day') 
and current_timestamp
# 最近一天(昨天)
SELECT current_timestamp - interval '1 day'
# 最近三天
SELECT current_timestamp - interval '3 day'
# 最近一周
SELECT current_timestamp - interval '7 day'
# 最近一個月(當前時間向前推進一個月)
SELECT current_timestamp - interval '1 month'
# 最近一年(當前時間向前推進一年)
SELECT current_timestamp - interval '1 year'
# 最近一小時(當前時間向前推一小時)
SELECT current_timestamp - interval '1 hour'
# 最近一分鐘(當前時間向前推一分鐘)
SELECT current_timestamp - interval '1 min'
# 最近60秒(當前時間向前推60秒)
SELECT current_timestamp - interval '60 second'

最近七天中每天的累計歷史總量:

步驟:

1)先統計出近7天每天的數量

2)后統計出7天前的累計歷史總量

3)再對第(1)步中獲取的結果進行累計求和,使用cumsum()函數

4)最后在第(3)步結果的基礎上,加上7天前的累計歷史總量(也就是第2步的結果)

# 趨勢
def getWeekTrends(self):
  try:
    database = DataBase()
    sql = """select s.zhongzhi_Date, s.data_num
        from (select to_char(jiaozheng_jieshushijian, 'yyyy-mm-dd') as zhongzhi_Date,
        count(1) as data_num
        from shequjz_jibenxx t
        where t.jiaozheng_jieshushijian >= to_date('{}', 'yyyy-mm-dd')
        and t.jiaozheng_jieshushijian  to_date('{}', 'yyyy-mm-dd') 
        group by to_char(jiaozheng_jieshushijian, 'yyyy-mm-dd') ) s""".format(lastweek, today[:10])
    res_df = database.queryData(sql, flag=True)
 
    sql_total = """select count(1) FROM "shequjz_jibenxx" where rujiaoriqi is not null 
           and zhongzhiriqi is null and to_char(rujiaoriqi,'yyyy-mm-dd')'{}'""".format(lastweek)
    res_total = database.queryData(sql_total, count=1, flag=False)  #7131
 
    res_df['cumsum'] = res_df['data_num'].cumsum() # 累計求和
    res_df['cumsum'] = res_df['cumsum'] + res_total[0]
    res_df = res_df[['zhongzhi_date', 'cumsum']].to_dict(orient='records')
    res = {'code': 1, 'message': '數據獲取成功', 'data': res_df}
    print(res)
    return res
  except Exception as e:
    error_info = '數據獲取錯誤:{}'.format(e)
    logger.error(error_info)
    res = {'code': 0, 'message': error_info}
    return res
{'code': 1, 'message': '數據獲取成功', 'data': [
{'zhongzhi_date': '2020-11-13', 'cumsum': 7148}, 
{'zhongzhi_date': '2020-11-10', 'cumsum': 7161}, 
{'zhongzhi_date': '2020-11-11', 'cumsum': 7195}, 
{'zhongzhi_date': '2020-11-12', 'cumsum': 7210}, 
{'zhongzhi_date': '2020-11-09', 'cumsum': 7222}, 
{'zhongzhi_date': '2020-11-14', 'cumsum': 7229}, 
{'zhongzhi_date': '2020-11-15', 'cumsum': 7238}]}

postgresql按周統計數據

(實際統計的是 上周日到周六 7天的數據):

因為外國人的習慣是一周從周日開始,二我們中國人的習慣一周的開始是星期一,這里 -1 即將顯示日期從周日變成了周一,但是內部統計的數量還是從 上周日到周六進行 統計的,改變的僅僅是顯示星期一的時間。

提取當前星期幾: 1

SELECT EXTRACT(DOW FROM CURRENT_DATE)

提取當前日期: 2020-11-16 00:00:00

SELECT CURRENT_DATE-(EXTRACT(DOW FROM CURRENT_DATE)-1||'day')::interval diffday;

按周統計數據一:

select to_char(jiaozheng_jieshushijian::DATE-(extract(dow from "jiaozheng_jieshushijian"::TIMESTAMP)-1||'day')::interval, 'YYYY-mm-dd') date_,
count(1) from shequjz_jibenxx where jiaozheng_jieshushijian BETWEEN '2020-01-01' and '2020-11-16' 
 GROUP BY date_ order by date_

其中date_為一周中的第一天即星期一

按周統計數據二:

SELECT
to_char ( cda.jiaozheng_jieshushijian, 'yyyy ' ) || EXTRACT ( WEEK FROM cda.jiaozheng_jieshushijian ) :: INTEGER AS date_,
count( cda.id ) AS count,
cda.jiaozheng_jieshushijian AS times 
FROM
shequjz_jibenxx AS cda
 
WHERE
1 = 1 
AND to_char ( cda.jiaozheng_jieshushijian, 'YYYY-MM-DD HH24:MI:SS' ) BETWEEN '2020-10-01 00:00:00' AND '2020-11-12 00:00:00' 
GROUP BY
date_,
times 
ORDER BY
date_,
times DESC

postgresql中比較日期的四種方法

select * from user_info where create_date >= '2020-11-01' and create_date = '2020-11-16' 
select * from user_info where create_date between '2020-11-01' and '2020-11-16' 
select * from user_info where create_date >= '2020-11-01'::timestamp and create_date  '2020-11-16'::timestamp 
select * from user_info where create_date between to_date('2020-11-01','YYYY-MM-DD') and to_date('2020-11-16','YYYY-MM-DD')

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • postgreSql分組統計數據的實現代碼
  • Postgresql 存儲過程(plpgsql)兩層for循環的操作
  • postgresql 循環函數的簡單實現操作
  • 淺談PostgreSQL和SQLServer的一些差異
  • 解決PostgreSQL 執行超時的情況
  • postgresql 中的幾個 timeout參數 用法說明

標簽:杭州 辛集 溫州 榆林 海西 昭通 寶雞 濮陽

巨人網絡通訊聲明:本文標題《PostgreSQL完成按月累加的操作》,本文關鍵詞  PostgreSQL,完成,按月,累加,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PostgreSQL完成按月累加的操作》相關的同類信息!
  • 本頁收集關于PostgreSQL完成按月累加的操作的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    93久久精品日日躁夜夜躁欧美| 国产美女精品在线| 久久久不卡网国产精品一区| 成人午夜电影久久影院| 日本欧美一区二区在线观看| 日韩电影网1区2区| 国产精品美女www爽爽爽| 国产黄人亚洲片| 亚洲成人在线网站| 中文字幕一区二区三区蜜月| 91麻豆精品久久久久蜜臀| 91尤物视频在线观看| 奇米精品一区二区三区在线观看 | 不卡一区中文字幕| 日韩精品成人一区二区三区| 欧美不卡视频一区| 91精品国产一区二区人妖| 色噜噜狠狠一区二区三区果冻| 国产精品一二三四| 麻豆91在线播放免费| 午夜久久福利影院| 亚洲成人av电影| 亚洲国产日韩精品| 亚洲一区二区三区自拍| 亚洲欧美aⅴ...| 国产精品欧美精品| 国产精品素人视频| 国产日韩精品久久久| 久久午夜老司机| 精品国产乱码久久久久久夜甘婷婷 | 国产丶欧美丶日本不卡视频| 精品一区二区三区的国产在线播放| 亚洲 欧美综合在线网络| 亚洲精品欧美激情| 亚洲欧美激情在线| 亚洲伦理在线精品| 亚洲精品国产a| 亚洲夂夂婷婷色拍ww47| 夜夜夜精品看看| 亚洲一线二线三线久久久| 亚洲精品美国一| 亚洲一区在线播放| 五月激情六月综合| 午夜精品影院在线观看| 国产一区二区免费在线| 国产精品 欧美精品| 成人激情图片网| 94-欧美-setu| 欧美日韩在线一区二区| 欧美日韩国产区一| 日韩一区二区三区四区| 久久综合狠狠综合久久激情| 久久―日本道色综合久久| 中文字幕国产一区二区| 亚洲男人的天堂一区二区| 亚洲国产成人av| 久久99精品久久久久久久久久久久 | 欧美国产一区视频在线观看| 国产精品妹子av| 亚洲精品视频在线观看网站| 亚洲一区中文在线| 免费黄网站欧美| 国产精品99久久久久久有的能看| 播五月开心婷婷综合| 在线免费观看日本一区| 91麻豆精品国产91久久久资源速度 | 日韩欧美电影一区| 国产日本一区二区| 一区二区三区在线免费观看| 日韩电影在线一区二区| 国产激情偷乱视频一区二区三区| 99久久久免费精品国产一区二区| 欧美日韩一区二区在线观看| 欧美精品一区二区在线观看| 国产精品人妖ts系列视频| 亚洲中国最大av网站| 久草这里只有精品视频| 91丨porny丨在线| 欧美电视剧在线看免费| 亚洲欧美影音先锋| 免费xxxx性欧美18vr| caoporm超碰国产精品| 91.xcao| 欧美国产97人人爽人人喊| 五月激情丁香一区二区三区| 国产suv精品一区二区883| 欧美在线制服丝袜| 久久色中文字幕| 亚洲成av人影院| 成人av资源网站| 欧美电视剧免费全集观看| 亚洲欧洲综合另类在线| 国产乱一区二区| 欧美精品一级二级三级| 一区在线观看视频| 紧缚捆绑精品一区二区| 欧美日韩成人激情| 最新中文字幕一区二区三区 | 亚洲日本乱码在线观看| 久久91精品国产91久久小草| 在线观看日韩电影| 国产精品无码永久免费888| 蜜臀va亚洲va欧美va天堂| 色婷婷国产精品综合在线观看| 久久久久久久久久久久电影| 青青国产91久久久久久 | 欧美午夜精品免费| 综合激情网...| 欧美日韩视频在线观看一区二区三区| 2023国产精华国产精品| 日韩综合小视频| 91国产丝袜在线播放| 国产精品青草综合久久久久99| 麻豆国产欧美日韩综合精品二区| 色哟哟一区二区在线观看| 中文字幕的久久| 国产一区二区三区在线观看精品| 欧美一区二区三区视频免费播放 | 2022国产精品视频| 久久疯狂做爰流白浆xx| 欧美精品在线一区二区三区| 亚洲自拍偷拍综合| 在线观看视频欧美| 一区二区三区在线播| 一本一道波多野结衣一区二区| 欧美—级在线免费片| 风流少妇一区二区| 亚洲国产成人在线| 国产suv一区二区三区88区| 国产人成一区二区三区影院| 国内成人精品2018免费看| 2021久久国产精品不只是精品| 寂寞少妇一区二区三区| 欧美精品一区二区三区四区| 欧美96一区二区免费视频| 欧美一级片免费看| 玖玖九九国产精品| 精品久久久三级丝袜| 国产在线观看一区二区| 国产欧美一区二区三区在线看蜜臀| 国产精品自拍网站| 久久久久久久电影| 国产成人午夜高潮毛片| 中文字幕一区二区三区色视频| 91亚洲永久精品| 亚洲第一成人在线| 日韩三级在线观看| 国产综合久久久久久鬼色| 国产精品视频看| 不卡的看片网站| 亚洲综合一区二区三区| 欧美精品丝袜久久久中文字幕| 日本欧洲一区二区| 国产三区在线成人av| 99这里只有精品| 亚洲成av人影院在线观看网| 日韩欧美激情在线| 成人av在线资源网站| 亚洲综合色在线| 日韩精品专区在线影院重磅| 国产成人精品1024| 亚洲成人av一区二区| 精品国产区一区| 99久久精品99国产精品| 天天色天天爱天天射综合| 欧美sm极限捆绑bd| 99re成人在线| 天天综合日日夜夜精品| 国产午夜亚洲精品羞羞网站| 97se亚洲国产综合自在线观| 天天av天天翘天天综合网色鬼国产| 精品免费视频.| 97精品电影院| 美女视频黄频大全不卡视频在线播放| 久久日韩粉嫩一区二区三区| 欧美性受极品xxxx喷水| 久草热8精品视频在线观看| 亚洲视频 欧洲视频| 制服丝袜中文字幕亚洲| 国产成人高清在线| 日韩激情在线观看| 国产精品久久久久久久久免费相片| 欧美日韩中文字幕精品| 国产suv精品一区二区883| 午夜电影网一区| 国产精品美女久久福利网站 | 亚洲综合色噜噜狠狠| 久久嫩草精品久久久久| 日本精品一级二级| 国产精品影视在线观看| 岛国精品在线观看| 日本成人在线电影网| 亚洲欧洲在线观看av| 精品国产精品一区二区夜夜嗨| 91福利精品第一导航| 激情六月婷婷久久| 亚洲成人一区二区在线观看| 亚洲视频精选在线| 国产日韩欧美不卡在线| 91精品国产综合久久久久久漫画|