真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

怎么在postgresql中獲取指定的時(shí)間段-創(chuàng)新互聯(lián)

怎么在postgresql中獲取指定的時(shí)間段?針對(duì)這個(gè)問題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡(jiǎn)單易行的方法。

創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的天鎮(zhèn)網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(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
時(shí)間: 0.004s
受影響的行: 0

解析:

declare :聲明變量

CURRENT_DATE : 得到當(dāng)前日期

SELECT CURRENT_DATE;

結(jié)果:

date
2016-06-12

extract :從時(shí)間中抽出相應(yīng)的字段

DOW 一周里的第幾天 (sunday =0 saturday=6)

格式:

EXTRACT(field FROM source)

當(dāng)前日期是一周里面的第幾天

SELECT EXTRACT(DOW FROM CURRENT_DATE);

結(jié)果:

date_part
    0

INTERVAL :時(shí)間間隔類型

EXECUTE :執(zhí)行一個(gè)準(zhǔn)備好的查詢

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 將一個(gè)字符串轉(zhuǎn)換成數(shù)字

格式:

TO_NUMBER(string,format)
-- 一周里的日子(1-7;周日是1)
select to_char(CURRENT_DATE ,'D')
DDD 一年里的日子(001-366)
DD 一個(gè)月里的日子(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')
-- 因?yàn)榈玫降男瞧谝粸?,所以要減去2
select TO_NUMBER(to_char(CURRENT_DATE,'D'),'99')-2
-- 將得到的數(shù)字乘以 -1 比如例子中:-1*3 就是 -3 ,也就是減去 3天
select cast(-1*3 || 'days' as interval) 
-- 就是將當(dāng)天減去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');

補(bǔ)充:Postgresql數(shù)據(jù)數(shù)據(jù)庫中按日、月、周、年、時(shí)、分,30分鐘的統(tǒng)計(jì)解決方案

對(duì)要統(tǒng)計(jì)的時(shí)間字段進(jìn)行字符轉(zhuǎn)換處理,再按照其分組即可實(shí)現(xiàn)對(duì)數(shù)據(jù)進(jìn)行日,周,月,年,時(shí),分,秒的統(tǒng)計(jì)

1、按日統(tǒng)計(jì)

to_char( h.row_date, 'yyyy-MM-dd' ) AS row_date2
GROUP BY to_char( h.row_date, 'yyyy-MM-dd' )

2、按月統(tǒng)計(jì)

to_char(h.row_date, 'yyyy-MM' ) AS row_date2
GROUP BY to_char(h.row_date, 'yyyy-MM' )

3、按年統(tǒng)計(jì)

to_char( h.row_date,'yyyy' ) AS row_date2
GROUP BY to_char( h.row_date,'yyyy' )

4、按小時(shí)統(tǒng)計(jì)

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)計(jì)

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)計(jì)

按周統(tǒng)計(jì)最簡(jiǎn)單法

對(duì)時(shí)間row_date字段做處理,變成對(duì)應(yīng)日期周一時(shí)間,然后按這個(gè)周一的時(shí)間去統(tǒng)計(jì)。減1的操作表示為對(duì)應(yīng)日期的星期一,減1,2,3,4,5,6,7分別是對(duì)應(yīng)日期的周一,周二,周三,周四,周五、周六、周日。

to_char( h.row_date-(extract (dow from h.row_date) - 1 ||'day')::interval,'yyyy-MM-dd') row_date

然后按上面的語句分組統(tǒng)計(jì)即可實(shí)現(xiàn)按周統(tǒng)計(jì),下面對(duì)應(yīng)分組函數(shù)

GROUP BY to_char(h.row_date-(extract (dow from h.row_date) - 1 ||'day')::interval,'yyyy-MM-dd')

按周統(tǒng)計(jì)之方法二(較復(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)換成當(dāng)周周一的時(shí)間

//將周統(tǒng)計(jì)中獲取的如201636,表示2016年36周,獲取其周一的時(shí)間
  public String getFirstDayOfWeek(int year, int week) {
    // 先滾動(dòng)到該年
     nows.set(Calendar.YEAR, year);
    // 滾動(dòng)到周
     nows.set(Calendar.WEEK_OF_YEAR, week);
    // 得到該周第一天
     nows.set(Calendar.DAY_OF_WEEK, 2);
    String firstDay = df.format(nows.getTime());
    return firstDay;
    }

7、按30分鐘進(jìn)行統(tǒng)計(jì)

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中獲取指定的時(shí)間段問題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識(shí)。


本文題目:怎么在postgresql中獲取指定的時(shí)間段-創(chuàng)新互聯(lián)
URL地址:http://weahome.cn/article/cshcse.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部