【小計】PostgreSQL實現Oracle的trunc日期函數功能

來源:互聯網
上載者:User

標籤:postgresql   trunc   


create or replace function trunc(p_timestamp timestamp with time zone, p_formart varchar default ‘DD‘) returns timestamp without time zone as$$declare v_timestamp timestamp := null; v_formart varchar(10) := upper(p_formart);begin /* * 函數功能:對日期值進行格式化 * 參數說明: *   P_TIMESTAMP ( 需要格式話的日期值 ) *   P_FORMART  ( YYYY:年第一天; MM|MONTH|MON|RM:月第一天;  NULL|DD:當日; D:當前周第一天;  ....) * 返回格式:YYYY-MM-DD HH24(12):MI:SS (具體值由第二個參數決定) */ if p_timestamp is not null then  if v_formart in (‘YYYY‘, ‘YEAR‘) then   -- 當前年的第一天(YYYY-01-01 00:00:00)   v_timestamp := date_trunc(‘year‘, p_timestamp);  elsif v_formart in (‘MONTH‘, ‘MON‘, ‘MM‘, ‘RM‘) then   -- 當前月第一天(YYYY-MM-01 00:00:00)   v_timestamp := date_trunc(‘month‘, p_timestamp);  elsif v_formart in (‘DD‘, ‘DAY‘, ‘DY‘) then   -- 當天(YYYY-MM-DD 00:00:00)   v_timestamp := date_trunc(‘day‘, p_timestamp);  elsif v_formart = ‘D‘ then   -- 當前周第一天[周日為第一天](YYYY-MM-DD 00:00:00)   v_timestamp := (date_trunc(‘WEEK‘, p_timestamp) - interval‘1 day‘);  elsif v_formart in (‘W1‘, ‘W2‘, ‘W3‘, ‘W4‘, ‘W5‘, ‘W6‘, ‘W7‘) then   -- 當前周第幾天[周日為第一天](YYYY-MM-DD 00:00:00)   v_timestamp := date_trunc(‘WEEK‘, p_timestamp)::date + substr(v_formart, 2, 1)::integer - 2;  elsif v_formart ~ ‘^D\+?[0-9]*$‘ then   -- 當年第幾天(YYYY-MM-DD 00:00:00)   if substr(v_formart, 2, length(v_formart)-1)::integer between 1 and 366 then    v_timestamp := date_trunc(‘year‘, p_timestamp)::date + substr(v_formart, 2, length(v_formart)-1)::integer - 1;    if date_trunc(‘year‘, v_timestamp)::date > date_trunc(‘year‘, p_timestamp)::date then     v_timestamp := date_trunc(‘year‘, v_timestamp)::date - interval‘1 day‘;    end if;   else    raise exception ‘U-2001 [%] is not recognize. please enter "D[1~366]"‘, p_formart;   end if;  elsif v_formart in (‘HH‘, ‘HH24‘) then   v_timestamp := date_trunc(‘hour‘, p_timestamp);  elsif v_formart = ‘HH12‘ then   v_timestamp := to_char(p_timestamp, ‘yyyy-mm-dd hh12:00:00‘)::timestamp;  elsif v_formart in (‘MINUTE‘, ‘MI‘) then   v_timestamp := date_trunc(‘minute‘, p_timestamp);  elsif v_formart = ‘CC‘ then   v_timestamp := to_date((trunc(date_part(‘years‘, p_timestamp)::integer/100)*100+1)::varchar, ‘yyyy‘);  elsif v_formart in (‘HELP‘, ‘?‘) then   raise exception ‘U-2001 please enter formart code in ( YYYY|YEAR, MONTH|MON|MM|RM, DD|DAY|DY, D, W[1~7], D[1~366], HH|HH24, HH12, MINUTE|MI, CC )‘;  else   raise exception ‘U-2001 [%] is not recognize. you can try [help]‘, p_formart;  end if; else  v_timestamp := p_timestamp; end if; return v_timestamp;end;$$ language plpgsql; -- 測試資料select trunc(current_date, ‘D360‘), trunc(current_date, ‘D‘),trunc(current_date, ‘W1‘);


本文出自 “積跬步至千裡” 部落格,請務必保留此出處http://chnjone.blog.51cto.com/4311366/1658843

【小計】PostgreSQL實現Oracle的trunc日期函數功能

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.