好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > postgresql 實現得到時間對應周的周一案例

postgresql 實現得到時間對應周的周一案例

熱門標簽:漯河外呼電話系統 辦公外呼電話系統 外呼調研系統 美容工作室地圖標注 地圖標注和圖片名稱的區別 合肥公司外呼系統運營商 重慶自動外呼系統定制 海豐有多少商家沒有地圖標注 打電話智能電銷機器人授權

兩種方法:

第一種:

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$$

結果:

[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;

結果:

date
2016-06-12

extract :從時間中抽出相應的字段

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

格式:

EXTRACT(field FROM source)

當前日期是一周里面的第幾天

SELECT EXTRACT(DOW FROM CURRENT_DATE);

結果:

date_part
    0

INTERVAL :時間間隔類型

EXECUTE :執行一個準備好的查詢

RAISE NOTICE :把結果顯示出來

第二種:

SELECT CURRENT_DATE +cast(-1*(TO_NUMBER(to_char(CURRENT_DATE,'D'),'99')-2) ||' days' as interval);

結果:

?column?
2016-06-13 00:00:00

解析:

TO_NUMBER 將一個字符串轉換成數字

格式:

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
-- 將得到的字符串轉換成數字
select TO_NUMBER(to_char(CURRENT_DATE,'D'),'99')
-- 因為得到的星期一為2,所以要減去2
select TO_NUMBER(to_char(CURRENT_DATE,'D'),'99')-2
-- 將得到的數字乘以 -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數據數據庫中按日、月、周、年、時、分,30分鐘的統計解決方案

對要統計的時間字段進行字符轉換處理,再按照其分組即可實現對數據進行日,周,月,年,時,分,秒的統計

1、按日統計

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

2、按月統計

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

3、按年統計

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

4、按小時統計

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

5、按分鐘統計

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、按周統計

按周統計最簡單法

對時間row_date字段做處理,變成對應日期周一時間,然后按這個周一的時間去統計。減1的操作表示為對應日期的星期一,減1,2,3,4,5,6,7分別是對應日期的周一,周二,周三,周四,周五、周六、周日。

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

然后按上面的語句分組統計即可實現按周統計,下面對應分組函數

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

按周統計之方法二(較復雜,不建議使用)

to_char(h.row_date, 'yyyy' ) || EXTRACT ( week FROM h.row_date ) :: INTEGER ASrow_date2

獲取到數據庫輸出的字段中的年份和周數。

String row_date=rs.getString("row_date2");
//獲取數據庫輸出日期的年份
 int year=Integer.parseInt(row_date.substring(0, 4));
//獲取數據庫輸出日期的周數
  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);

將查詢出的內容日期轉換成當周周一的時間

//將周統計中獲取的如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分鐘進行統計

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

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

您可能感興趣的文章:
  • postgresql 實現查詢某時間區間的所有日期案例
  • PostgreSQL 分頁查詢時間的2種比較方法小結
  • 淺析postgresql 數據庫 TimescaleDB 修改分區時間范圍
  • postgresql連續歸檔及時間點恢復的操作
  • postgresql數據庫使用說明_實現時間范圍查詢

標簽:晉城 烏海 株洲 來賓 蚌埠 衡陽 珠海 錦州

巨人網絡通訊聲明:本文標題《postgresql 實現得到時間對應周的周一案例》,本文關鍵詞  postgresql,實現,得到,時間,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《postgresql 實現得到時間對應周的周一案例》相關的同類信息!
  • 本頁收集關于postgresql 實現得到時間對應周的周一案例的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 欧美专区在线播放| 娇妻被邻居灌满精H催眠| 我帮妺妺洗澡忍不住C了她| 女人与拘做受A片| 国产真实夫妇视频| 女人被狂躁视频网站免费| 国产精品户外野外| 国产丝袜熟女一区二区在线| 欧美熟妇另类久久久久久多毛 | 她儿砸被大佬盯上了| 狂c亲女的文H共妻| 艳鉧动漫无码1~6无删减| 成年人视频在线免费| 美女扒开尿口给男人桶动态图| 又爽又黄又舒服激情视频 | 国产精品爱久久久久久久电影蜜臀 | 色94色欧美一区| 久久久无码精品亚洲A片优缺点| 最美情侣国语版免费高清视频| 俄罗斯美女在线观看一区| 黄色大全| 女性脱??给我揉??图片+亲嘴| 日本免费xxxx| 麻豆视频免费看| 淫牛网| 免费无码又爽又刺激片软件| 免费xxxxx在线观看网站| 欧美一级专区免费大片| 亚洲AV秘?精品老牛影视| 肉翻漫画| 美女光着胸让男生狂摸动态图| 哦哦好爽| 欧美自拍偷拍| 成品网站1688免费入口网页版怎样 | 刘老汉翁熄系列新婚| 这几天没c你了是不是皮痒了| 日本黄色aa| ferx性欧美高清| 无码AV精品-区二区三| 国产日韩欧美二区| 天天摸天天躁天天添天天爽|