a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 數(shù)據(jù)庫 > Oracle > 正文

Oracle數(shù)據(jù)庫中每月工作日計(jì)算代碼分析

2024-08-29 13:51:39
字體:
供稿:網(wǎng)友
SQL> SELECT TEXT FROM USER_SOURCE WHERE TYPE='PROCEDURE' AND NAME='GZR';
  
  TEXT                                                
  ----------------------------------------------------------------------------------------------------
  procedure gzr(v_nowdate in varchar2) as                              
  v_firstsaturday varchar2(10);                                   
  v_outdate date;                                          
  v_countworkday number(10);                                     
  begin                                               
        select to_char(next_day(to_date(concat(v_nowdate,'01'),'yyyymmdd'),1)-1,'dd')         
       into v_firstsaturday                                      
       from sys.dual;                                         
   v_countworkday:=to_number(v_firstsaturday)-1;                          
   loop                                               
    v_outdate:=to_date(concat(v_nowdate,v_firstsaturday+7),'yyyymmdd');              
    if v_outdate yyymm'),'01'),'yyyymmdd') then                                   
                                                    
     v_countworkday:=v_countworkday+5;                              
     else                                             
     v_countworkday:=v_countworkday+5-to_number(v_outdate-to_date(concat(to_char(add_months(sysdate
  ,1),'yyyymm'),'01'),'yyyymmdd'));                                 
                                                    
    end if;                                            
   exit when v_outdate>=to_date(concat(to_char(add_months(sysdate,1),'yyyymm'),'01'),'yyyymmdd');  
  
  TEXT
  
  CREATE OR REPLACE FUNCTION Get_WorkingDays(
   ny IN VARCHAR2
  ) RETURN INTEGER IS
  /*------------------------------------------------------------------------------------------
  函數(shù)名稱:Get_WorkingDays
  中文名稱:求某一年月中共有多少工作日
  作者姓名: XINGPING
  編寫時(shí)間: 2004-05-22
  輸入?yún)?shù):NY:所求包含工作日數(shù)的年月,格式為yyyymm,如200405
  返 回 值:整型值,包含的工作日數(shù)目。
  算法描述:
    1).列舉出參數(shù)給出的年月中的每一天。這里使用了一個(gè)表(ljrq是我的庫中的一張表。這個(gè)表可以是有權(quán)訪問的、記錄條數(shù)至少為31的任意一張表或視圖)來構(gòu)造出某年月的每一天。
    2).用這些日期和一個(gè)已知星期幾的日期相減(2001-12-30是星期天),所得的差再對7求模。假如所求年月在2001-12-30以前,那么所得的差既是負(fù)數(shù),求模后所得值范圍為大于-6,小于0,如-1表示星期六,故先將求模的結(jié)果加7,再求7的模.
    3).過濾掉結(jié)果集兄滴?和6的元素,然后求count,所得即為工作日數(shù)目。   
  -------------------------------------------------------------------------------------------------*/
   Result INTEGER;
  BEGIN
   SELECT COUNT(*) INTO Result
    FROM (SELECT MOD(MOD(q.rq-to_date('2001-12-30','yyyy-mm-dd'),7),7) weekday
        FROM ( SELECT to_date(nyt.dd,'yyyymmdd') rq
             FROM (SELECT substr(100+ROWNUM,2,2) dd
                 FROM ljrq z WHERE Rownum<=31
               ) t
             WHERE to_date(nyt.dd,'yyyymmdd')
              BETWEEN to_date(ny,'yyyymm')

                AND last_day(to_date(ny,'yyyymm'))
           )q
       ) a 
    WHERE a.weekday NOT IN(0,6);  
   RETURN Result; 
  END Get_WorkingDays;
  
  CREATE OR REPLACE FUNCTION Get_WorkingDays(
   ny IN VARCHAR2
  ) RETURN INTEGER IS
  /*-----------------------------------------------------------------------------------------
  函數(shù)名稱:Get_WorkingDays
  中文名稱:求某一年月中共有多少工作日
  作者姓名: XINGPING
  編寫時(shí)間: 2004-05-23
  輸入?yún)?shù):NY:所求包含工作日數(shù)的年月,格式為yyyymm,如200405
  返 回 值:整型值,包含的工作日數(shù)目。
  算法描述:使用Last_day函數(shù)計(jì)算出參數(shù)所給年月共包含多少天,根據(jù)這個(gè)值來構(gòu)造一個(gè)循環(huán)。在這個(gè)循環(huán)中先求這個(gè)月的每一天與一個(gè)已知是星期天的日期(2001-12-30是星期天)的差,所得的差再對7求模。假如所求日期在2001-12-30以前,那么所得的差既是負(fù)數(shù),求模后所得值范圍為大于-6,小于0,如-1表示星期六,故先將求模的結(jié)果加7,再求7的模. 如過所得值不等于0和6(即不是星期六和星期天),則算一個(gè)工作日。   
  ----------------------------------------------------------------------------------------*/
   Result INTEGER := 0;
   myts INTEGER;   --所給年月的天數(shù)
   scts INTEGER;   --某天距2001-12-30所差的天數(shù)
   rq  DATE;
   djt INTEGER := 1;  --
  BEGIN
   myts := to_char(last_day(to_date(ny,'yyyymm')),'dd'); 
   LOOP
    rq := TO_date(nysubstr(100+djt,2),'yyyymmdd');
    scts := rq - to_date('2001-12-30','yyyy-mm-dd');
    IF MOD(MOD(scts,7)+7,7) NOT IN(0,6) THEN
     Result := Result + 1;
    END IF;
    djt := djt + 1; 
    EXIT WHEN djt>myts;
   END LOOP; 
   RETURN Result; 
  END Get_WorkingDays;
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 国产片一区二区 | 国产成人精品在线观看 | 91免费版在线看 | 美日韩在线观看 | 日本高清视频一区二区三区 | 亚洲精品v| 亚洲午码 | 久久国产一区二区三区 | 草草电影| 亚洲系列第一页 | 中文字幕一区在线观看视频 | 日韩欧美在线播放视频 | 91精品国产欧美一区二区 | 自拍视频免费 | 国产91在线播放精品91 | 日韩精品一区二区三区第95 | 成人黄色在线观看 | 男女网站在线观看 | 久久逼逼 | 成人91免费版 | 日韩中文字幕在线播放 | 中文字幕爱爱视频 | 午夜精品久久久久久久久久久久久 | 亚洲一区日韩 | 99国产精品久久久久久久成人热 | av一级毛片 | 毛片久久久 | 国产精品久久久久久久久久 | 一本一本久久a久久精品牛牛影视 | 久久久九九九九 | 一级片日韩 | 偷拍电影一区二区三区 | 久久国产区 | 日韩一区电影 | 在线播放91| 国产一级黄色大片 | 91精彩视频 | 成人福利视频 | 亚洲综合色视频在线观看 | 日韩精品一区二 | 久草精品在线 |