postgresql 實(shí)現(xiàn)得到時(shí)間對應(yīng)周的周一案例
兩種方法:
第一種:
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ì)解決方案
對要統(tǒng)計(jì)的時(shí)間字段進(jìn)行字符轉(zhuǎn)換處理,再按照其分組即可實(shí)現(xiàn)對數(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ì)最簡單法
對時(shí)間row_date字段做處理,變成對應(yīng)日期周一時(shí)間,然后按這個(gè)周一的時(shí)間去統(tǒng)計(jì)。減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)計(jì)即可實(shí)現(xiàn)按周統(tǒng)計(jì),下面對應(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 hh24:mi'),15, 16) :: integer <=30 then to_char(h.row_date, 'yyyy-mm-dd hh24')||':30' else to_char( h.row_date, 'yyyy-mm-ddhh24' )||':60' end as row_date2 GROUP BY case when substr( to_char(h.row_date, 'yyyy-mm-dd hh24:mi'),15, 16) :: integer <=30 then to_char(h.row_date, 'yyyy-mm-dd hh24')||':30' else to_char( h.row_date, 'yyyy-mm-ddhh24' )||':60' end
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
解決PostgreSQL數(shù)據(jù)遷移過程中的數(shù)據(jù)類型不匹配問題
在數(shù)據(jù)遷移的過程中,經(jīng)常會(huì)遇到源數(shù)據(jù)庫和目標(biāo)數(shù)據(jù)庫之間的數(shù)據(jù)類型不匹配的情況,對于 PostgreSQL 數(shù)據(jù)庫來說,處理這種數(shù)據(jù)類型不匹配問題需要一些特定的策略和技巧,需要的朋友可以參考下2024-07-07
postgreSQL使用pgAdmin備份服務(wù)器數(shù)據(jù)的方法
這篇文章主要介紹了postgreSQL使用pgAdmin備份服務(wù)器數(shù)據(jù)的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02
postgresql coalesce函數(shù)數(shù)據(jù)轉(zhuǎn)換方式
這篇文章主要介紹了postgresql coalesce函數(shù)數(shù)據(jù)轉(zhuǎn)換方式,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01
Linux CentOS 7安裝PostgreSQL9.3圖文教程
這篇文章主要為大家詳細(xì)介紹了Linux CentOS 7安裝PostgresSQL9.3圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11
psql除法保留小數(shù),實(shí)現(xiàn)向上取整和向下取整操作
這篇文章主要介紹了psql除法保留小數(shù),實(shí)現(xiàn)向上取整和向下取整操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01
SpringBoot3集成PostgreSQL的詳細(xì)過程
PostgreSQL是一個(gè)功能強(qiáng)大的開源數(shù)據(jù)庫系統(tǒng),具有可靠性、穩(wěn)定性、數(shù)據(jù)一致性等特點(diǎn),且可以運(yùn)行在所有主流操作系統(tǒng)上,包括Linux、Unix、Windows等,這篇文章主要介紹了SpringBoot3集成PostgreSQL,需要的朋友可以參考下2024-03-03
PotgreSQL?基于時(shí)間點(diǎn)恢復(fù)過程
本篇文章介紹?PostgreSQL?基于時(shí)間點(diǎn)恢復(fù)(point-in-time-recover)需要的條件及恢復(fù)過程,屬于操作說明,對PotgreSQL?時(shí)間點(diǎn)恢復(fù)相關(guān)知識(shí)感興趣的朋友跟隨小編一起看看吧2023-08-08
Postgresql 賦予用戶權(quán)限和撤銷權(quán)限的實(shí)例
這篇文章主要介紹了Postgresql 賦予用戶權(quán)限和撤銷權(quán)限的實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01

