怎么在postgresql中獲取指定的時間段?針對這個問題,這篇文章詳細介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
創(chuàng)新互聯(lián)堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站建設(shè)、網(wǎng)站設(shè)計、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的天鎮(zhèn)網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!DO $$ declare d int; declare d1 varchar(100); declare d2 varchar(100); declare d3 date; declare d4 date; begin d3:= CURRENT_DATE; d1:='select date'''|| d3 ||''''; d:=(SELECT EXTRACT(DOW FROM d3))-1; d2:=d1 || '-INTERVAL ''' || d || ' day '' '; EXECUTE d2 into d4; RAISE NOTICE 'ok %',d4; end$$
結(jié)果:
[SQL]DO $$ declare d int; declare d1 varchar(100); declare d2 varchar(100); declare d3 date; declare d4 date; begin d3:= CURRENT_DATE; d1:='select date'''|| d3 ||''''; d:=(SELECT EXTRACT(DOW FROM d3))-1; d2:=d1 || '-INTERVAL ''' || d || ' day '' '; EXECUTE d2 into d4; RAISE NOTICE 'ok %',d4; end$$ NOTICE: ok 2016-06-13 時間: 0.004s 受影響的行: 0
解析:
declare :聲明變量
CURRENT_DATE : 得到當前日期
SELECT CURRENT_DATE;
結(jié)果:
date 2016-06-12
extract :從時間中抽出相應(yīng)的字段
DOW 一周里的第幾天 (sunday =0 saturday=6)
格式:
EXTRACT(field FROM source)
當前日期是一周里面的第幾天
SELECT EXTRACT(DOW FROM CURRENT_DATE);
結(jié)果:
date_part 0
INTERVAL :時間間隔類型
EXECUTE :執(zhí)行一個準備好的查詢
RAISE NOTICE :把結(jié)果顯示出來
SELECT CURRENT_DATE +cast(-1*(TO_NUMBER(to_char(CURRENT_DATE,'D'),'99')-2) ||' days' as interval);
結(jié)果:
?column? 2016-06-13 00:00:00
解析:
TO_NUMBER 將一個字符串轉(zhuǎn)換成數(shù)字
格式:
TO_NUMBER(string,format)
-- 一周里的日子(1-7;周日是1) select to_char(CURRENT_DATE ,'D') DDD 一年里的日子(001-366) DD 一個月里的日子(01-31) D 一周里的日子(1-7;周日是1) select to_char (to_date('2016-06-12','yyyy-mm-dd'),'D') select to_number(‘1.1','9.99') from dual; 1.1 select to_number(‘1.121','9.99') from dual; 1.12 -- 將得到的字符串轉(zhuǎn)換成數(shù)字 select TO_NUMBER(to_char(CURRENT_DATE,'D'),'99') -- 因為得到的星期一為2,所以要減去2 select TO_NUMBER(to_char(CURRENT_DATE,'D'),'99')-2 -- 將得到的數(shù)字乘以 -1 比如例子中:-1*3 就是 -3 ,也就是減去 3天 select cast(-1*3 || 'days' as interval) -- 就是將當天減去0天 得到了星期一的日期 select cast(-1*0 || 'days' as interval) + CURRENT_DATE SELECT to_char(CURRENT_DATE +cast(-1*(TO_NUMBER(to_char(CURRENT_DATE,'D'),'99')-2) ||' days' as interval),'yyyy-mm-dd');
補充:Postgresql數(shù)據(jù)數(shù)據(jù)庫中按日、月、周、年、時、分,30分鐘的統(tǒng)計解決方案
對要統(tǒng)計的時間字段進行字符轉(zhuǎn)換處理,再按照其分組即可實現(xiàn)對數(shù)據(jù)進行日,周,月,年,時,分,秒的統(tǒng)計
1、按日統(tǒng)計
to_char( h.row_date, 'yyyy-MM-dd' ) AS row_date2 GROUP BY to_char( h.row_date, 'yyyy-MM-dd' )
2、按月統(tǒng)計
to_char(h.row_date, 'yyyy-MM' ) AS row_date2 GROUP BY to_char(h.row_date, 'yyyy-MM' )
3、按年統(tǒng)計
to_char( h.row_date,'yyyy' ) AS row_date2 GROUP BY to_char( h.row_date,'yyyy' )
4、按小時統(tǒng)計
to_char( h.row_date, 'yyyy-MM-dd HH' ) AS row_date2 GROUP BY to_char( h.row_date, 'yyyy-MM-dd HH' )
5、按分鐘統(tǒng)計
to_char( h.row_date, 'yyyy-MM-dd HH:mm' ) AS row_date2 GROUP BY to_char( h.row_date, 'yyyy-MM-dd HH:mm' )
6、按周統(tǒng)計
按周統(tǒng)計最簡單法
對時間row_date字段做處理,變成對應(yīng)日期周一時間,然后按這個周一的時間去統(tǒng)計。減1的操作表示為對應(yīng)日期的星期一,減1,2,3,4,5,6,7分別是對應(yīng)日期的周一,周二,周三,周四,周五、周六、周日。
to_char( h.row_date-(extract (dow from h.row_date) - 1 ||'day')::interval,'yyyy-MM-dd') row_date
然后按上面的語句分組統(tǒng)計即可實現(xiàn)按周統(tǒng)計,下面對應(yīng)分組函數(shù)
GROUP BY to_char(h.row_date-(extract (dow from h.row_date) - 1 ||'day')::interval,'yyyy-MM-dd')
按周統(tǒng)計之方法二(較復(fù)雜,不建議使用)
to_char(h.row_date, 'yyyy' ) || EXTRACT ( week FROM h.row_date ) :: INTEGER ASrow_date2
獲取到數(shù)據(jù)庫輸出的字段中的年份和周數(shù)。
String row_date=rs.getString("row_date2"); //獲取數(shù)據(jù)庫輸出日期的年份 int year=Integer.parseInt(row_date.substring(0, 4)); //獲取數(shù)據(jù)庫輸出日期的周數(shù) if(row_date.length()>=6){ week=Integer.parseInt(row_date.substring(4,6));} else{ week=Integer.parseInt(row_date.substring(4,5)); } String row_date2=getFirstDayOfWeek(year, week); trafficMap.put("row_date", row_date2);
將查詢出的內(nèi)容日期轉(zhuǎn)換成當周周一的時間
//將周統(tǒng)計中獲取的如201636,表示2016年36周,獲取其周一的時間 public String getFirstDayOfWeek(int year, int week) { // 先滾動到該年 nows.set(Calendar.YEAR, year); // 滾動到周 nows.set(Calendar.WEEK_OF_YEAR, week); // 得到該周第一天 nows.set(Calendar.DAY_OF_WEEK, 2); String firstDay = df.format(nows.getTime()); return firstDay; }
7、按30分鐘進行統(tǒng)計
case when substr( to_char(h.row_date, 'yyyy-mm-dd hh34:mi'),15, 16) :: integer <=30 then to_char(h.row_date, 'yyyy-mm-dd hh34')||':30' else to_char( h.row_date, 'yyyy-mm-ddhh34' )||':60' end as row_date2 GROUP BY case when substr( to_char(h.row_date, 'yyyy-mm-dd hh34:mi'),15, 16) :: integer <=30 then to_char(h.row_date, 'yyyy-mm-dd hh34')||':30' else to_char( h.row_date, 'yyyy-mm-ddhh34' )||':60' end
關(guān)于怎么在postgresql中獲取指定的時間段問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識。
本文名稱:怎么在postgresql中獲取指定的時間段-創(chuàng)新互聯(lián)
當前URL:http://jinyejixie.com/article34/cshcse.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁設(shè)計公司、網(wǎng)站營銷、企業(yè)網(wǎng)站制作、移動網(wǎng)站建設(shè)、Google、域名注冊
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容