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

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:3日期:2023-11-25 18:35:54
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');TEXTCREATE OR REPLACE FUNCTION Get_WorkingDays( ny IN VARCHAR2) RETURN INTEGER IS/*------------------------------------------------------------------------------------------函數(shù)名稱:Get_WorkingDays中文名稱:求某一年月中共有多少工作日作者姓名: XINGPING編寫時間: 2004-05-22輸入?yún)?shù):NY:所求包含工作日數(shù)的年月,格式為yyyymm,如200405返 回 值:整型值,包含的工作日數(shù)目。算法描述:1).列舉出參數(shù)給出的年月中的每一天。這里使用了一個表(ljrq是我的庫中的一張表。這個表可以是有權(quán)訪問的、記錄條數(shù)至少為31的任意一張表或視圖)來構(gòu)造出某年月的每一天。2).用這些日期和一個已知星期幾的日期相減(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 ResultFROM (SELECT MOD(MOD(q.rq-to_date('2001-12-30','yyyy-mm-dd'),7),7) weekdayFROM ( 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編寫時間: 2004-05-23輸入?yún)?shù):NY:所求包含工作日數(shù)的年月,格式為yyyymm,如200405返 回 值:整型值,包含的工作日數(shù)目。算法描述:使用Last_day函數(shù)計算出參數(shù)所給年月共包含多少天,根據(jù)這個值來構(gòu)造一個循環(huán)。在這個循環(huán)中先求這個月的每一天與一個已知是星期天的日期(2001-12-30是星期天)的差,所得的差再對7求模。假如所求日期在2001-12-30以前,那么所得的差既是負(fù)數(shù),求模后所得值范圍為大于-6,小于0,如-1表示星期六,故先將求模的結(jié)果加7,再求7的模. 如過所得值不等于0和6(即不是星期六和星期天),則算一個工作日。 ----------------------------------------------------------------------------------------*/ 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;
標(biāo)簽: Oracle 數(shù)據(jù)庫
主站蜘蛛池模板: 国产一区二区久久 | 波多野结衣一区二区在线 | 风流慈禧一级毛片在线播放 | 国产精品成aⅴ人片在线观看 | 国产a久久精品一区二区三区 | 日韩大片高清播放器大全 | 日本一级毛片高清免费观看视频 | 理论片中文字幕 | 欧美久久久久 | 日韩在线观看一区 | 在线观看成年人免费视频 | 亚洲美色综合天天久久综合精品 | 高清国产一区二区三区 | 欧美激情亚洲一区中文字幕 | 国产精品无打码在线播放9久 | 99这里只有精品视频 | 欧美国产亚洲一区 | 日韩一区二区三区四区不卡 | 日本无遮 | 亚洲国产欧洲精品路线久久 | 国产精品国产亚洲精品不卡 | 久操视频免费在线观看 | 日韩久久中文字幕 | 怡红院在线观看在线视频 | 亚洲欧美在线观看 | 久操视频免费在线观看 | 欧美啪啪一级毛片 | 久久久久久久久影院 | 97久久天天综合色天天综合色 | 中午字幕在线观看 | 欧美一区二区三区高清视频 | 久久88| m男亚洲一区中文字幕 | 欧美一级片在线视频 | 一级爱爱片一级毛片-一毛 一级爱做片免费观看久久 一级白嫩美女毛片免费 | 国产欧美视频一区二区三区 | 经典香港a毛片免费观看 | 亚欧美图片自偷自拍另类 | 黄色毛片视频校园交易 | 欧美在线视频二区 | 国产精品99久久久久久www |