国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

Oracle數據庫如何獲取當前自然周,當前周的起始和結束日期

瀏覽:95日期:2023-03-12 15:25:35
目錄
  • Oracle獲取當前自然周,當前周的起始和結束日期
  • Oracle獲取自然周數
    • 1. 按天統計
    • 2. 按自然周統計
    • 3. 按月統計
    • 4. 按季統計
    • 5. 按年統計
  • 總結

    Oracle獲取當前自然周,當前周的起始和結束日期

    SELECT to_char(sysdate,"iw")   from dual; --本周是第幾個自然周SELECT to_char(sysdate,"yyyy") into v_sbzq_nf from dual;  -- 當前年份SELECT to_char(TRUNC(TO_DATE(to_char(sysdate,"yyyy-MM-dd"),"yyyy-MM-dd"),"IW"),"yyyy-MM-dd")  FROM DUAL;--本周的起始時間(本周周一日期)SELECT to_char(TRUNC(TO_DATE(to_char(sysdate,"yyyy-MM-dd"),"YYYY-MM-DD"),"IW") + 6,"yyyy-MM-dd") FROM DUAL;--本周的結束時間(本周周日日期)

    下面是使用存儲過程向數據庫中插入一條數據

    數據格式 : 上報周期 起始時間 結束時間

    xxxx年第xx周 xx.xx xx.xx

    存儲過程如下:

    create or replace procedure PRC_T_SJSB_ZYGYPJG is   v_sbzq_zs varchar2(20);--上報周期周數   v_sbzq_nf varchar2(10); --上報周期年份   v_start varchar2(10);  --起始月份   v_end varchar2(10);  --結束月份   v_sbzq varchar2(20); --上報周期begin   SELECT to_char(sysdate,"iw") into  v_sbzq_zs from dual; --本周是第幾個自然周   SELECT to_char(sysdate,"yyyy") into v_sbzq_nf from dual;   SELECT to_char(TRUNC(TO_DATE(to_char(sysdate,"yyyy-MM-dd"),"yyyy-MM-dd"),"IW"),"yyyy-MM-dd") into v_start  FROM DUAL;--本周的起始時間(本周周一日期)   SELECT to_char(TRUNC(TO_DATE(to_char(sysdate,"yyyy-MM-dd"),"YYYY-MM-DD"),"IW") + 6,"yyyy-MM-dd") into v_end  FROM DUAL;--本周的結束時間(本周周日日期)   v_start:=substr(v_start,6);   v_end :=substr(v_end,6);   v_start :=replace(v_start,"/",".");   v_start :=replace(v_start,"-",".");   v_end :=replace(v_end, "/",".");   v_end :=replace(v_end, "-",".");   v_sbzq :=v_sbzq_nf||"年第"||v_sbzq_zs||"周";   insert into T_SJSB_ZYGYPJG (sbzq,sbzt,startdate,enddate) values(v_sbzq,"0",v_start,v_end);     commit;end PRC_T_SJSB_ZYGYPJG;

    Oracle獲取自然周數

    在Oracle中,Mysql中以及Hive中,SQL實現同樣的功能有時候可能要遵循不同的語法結構,尤其在日期操作方面區別較為明顯。接下來,將Oracle中常用的周期統計梳理出來。

    1. 按天統計

    Oracle中通過to_char()函數來操作日期變量,通過其中的格式參數配置輸出日期的格式。

    格式參數值為’yyyymmdd’時,將日期統一轉換為yyyymmdd(年月日)的方式輸出。

    select to_char(created_time,"yyyymmdd") as day,count(mobile_no)from tablewhere to_char(created_time,"yyyymmdd") >= 20181201group by to_char(created_time,"yyyymmdd")order by min(created_time) asc

    輸出的結果如下所示:

    2. 按自然周統計

    to_char()函數的格式參數值為’iw’時,表示按自然周方式輸出日期在全年中的周數排序值,自然周即日歷上顯示的周排列結果。

    如果只輸出周數,不便于排查數據,所以按自然周進行聚合時,最好能把該自然周的起始日期或結束日期顯示出來,使結果一目了然。

    select to_char(created_time,"iw") as week, min(created_time), count(mobile_no)from tablewhere to_char(created_time,"yyyymmdd") >= 20181201group by to_char(created_time,"iw")order by min(created_time) asc

    結果如下所示,其中week表示周數。通過MIN(created_time)可以展示出每個自然周的起始日期:

    3. 按月統計

    to_char()函數的格式參數值為’yyyymm’時可輸出格式為yyyymm(年月)的月份統計結果。

    select to_char(created_time,"yyyymm") as Month, count(mobile_no)from tablewhere to_char(created_time,"yyyymm") >= 20181201group by to_char(created_time,"yyyymm")

    其結果如下所示:

    4. 按季統計

    to_char()的格式參數值為’q’,可實現按季度輸出統計結果。

    select to_char(created_time,"q") as q,count(mobile_no)from tablewhere to_char(created_time,"yyyymmdd") >= 20180101group by to_char(created_time,"q")order by min(created_time) asc

    其結果如下所示,Q表示季度。

    5. 按年統計

    to_char()函數的參數值為’yyyy’時可以實現按年輸出統計結果。

    select to_char(created_time,"yyyy") as y, count(mobile_no)from tablewhere to_char(created_time,"yyyy") >= 2016group by to_char(created_time,"yyyy")order by y asc

    其輸出結果如下所示:

    總結

    以上為個人經驗,希望能給大家一個參考,也希望大家多多支持。

    標簽: Oracle
    主站蜘蛛池模板: 一级一级一片在线观看 | 久久一级黄色片 | 最新国产三级久久 | 欧美成人免费全部色播 | 欧美在线观看一区二区 | 色综合久久88色综合天天小说 | 在线欧洲成人免费视频 | 欧美在线视频一区二区 | 欧美一级免费观看 | 国产日韩欧美一区二区三区综合 | 在线观看片成人免费视频 | 在线观看aaa| 日韩乱淫 | 日本亚洲欧美国产日韩ay高清 | 波多野结衣在线观看3人 | 国产精品久久久久久免费播放 | 怡红院视频在线 | 在线视频一区二区日韩国产 | 美女双腿打开让男人桶爽网站 | 日韩一级a毛片欧美区 | 日本黄页网站免费大全 | 亚欧精品在线观看 | 激情综| 一 级做人爱全视频在线看 一本不卡 | 免费人成在线观看网站 | 最新欧美精品一区二区三区 | 欧美色道| 成人欧美精品久久久久影院 | 亚洲欧美精品一区二区 | 国产精品成人在线播放 | 韩国一大片a毛片 | 亚洲男人的天堂久久香蕉 | 伊人久久综合热青草 | 女人张开腿让男人桶个爽 | 亚洲毛片在线观看 | 成人国产精品一级毛片了 | 国外精品视频在线观看免费 | 美女一级毛片免费观看 | 韩国主播19福利视频在线 | 日本暖暖视频在线播放 | 99r8这是只有精品视频9 |