中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

Oracle數(shù)據(jù)庫日期遍歷功能的實現(xiàn)
來源:易賢網(wǎng) 閱讀:3797 次 日期:2015-04-21 14:18:53
溫馨提示:易賢網(wǎng)小編為您整理了“Oracle數(shù)據(jù)庫日期遍歷功能的實現(xiàn)”,方便廣大網(wǎng)友查閱!

遍歷開始日期到結(jié)束日期的每一天,若有查詢某段日期下有什么業(yè)務(wù)或者事件發(fā)生時,可用到此函數(shù)。

create or replace type class_date as object

(

year varchar2(10),

month varchar2(10),

day varchar2(20)

)--定義所需要的日期類

-----------------------------------------------------------------------------

create or replace type table_date is table of class_date--日期類返回table類型

------------------------------------------------------------------------------

create or replace function minusDay(firstDay in varchar2,lastDay in varchar2)

return table_date pipelined

as

firstYear number;

firstMonth number;

lastYear number;

lastMonth number;

totalDay number;

totalMonth number;

currentDay varchar2(40);

currentYear varchar2(40);

type tt is record(

day varchar2(20),

month varchar2(20),

year varchar2(20)

);

v_date tt;

begin

--第一天的日期轉(zhuǎn)換

select to_number(substr(firstDay,1,4))into firstYear from dual ;

select to_number(substr(firstDay,6,2)) into firstMonth from dual;

--第二天的日期轉(zhuǎn)換

select to_number(substr(lastDay,1,4)) into lastYear from dual;

select to_number(substr(lastDay,6,2)) into lastMonth from dual;

--1 第一個日期早于第二個日期

if to_number(to_date(firstDay,'yyyy-mm-dd')-to_date(lastDay,'yyyy-mm-dd')) <0 then

dbms_output.put_line('第一個日期早于第二個日期!');

end if;

--2 第一個日期晚于第二個日期

--------相同年份

if firstYear = lastYear then

v_date.year := to_char(firstYear);

--------相同月份

if firstMonth = lastMonth then

v_date.month := to_char(firstMonth);

-- 天數(shù)差

totalDay := to_number(to_date(lastDay,'yyyy-mm-dd')-to_date(firstDay,'yyyy-mm-dd'));

if totalDay = 0 then

v_date.day := firstDay;

pipe row(class_date(v_date.year,v_date.month,v_date.day));

elsif totalDay >0 then

for dayId in to_number(substr(firstDay,9,2))..to_number(substr(lastDay,9,2)) loop

v_date.day :=to_char(substr(firstDay,1,7)||'-'||to_char(dayId)) ;

pipe row(class_date(v_date.year,v_date.month,v_date.day));

dbms_output.put_line( v_date.day);

end loop;

end if;

--------不同月份

elsif firstMonth < lastMonth then

---月份差

--totalMonth := lastMonth - firstMonth;

for id in firstMonth..lastMonth-1 loop

v_date.month := to_char(id);

--滿月天數(shù)差

totalDay := to_number(last_day(to_date(firstYear||'-'||to_char(id)||'-'||'01','yyyy-mm-dd'))-to_date(firstYear||'-'||to_char(id)||'-'||'01','yyyy-mm-dd'))+1;

for dayId in 1..totalDay loop

v_date.day := substr(firstDay,1,7)||'-'||to_char(dayId) ;

pipe row(class_date(v_date.year,v_date.month,v_date.day));

dbms_output.put_line( v_date.day);

end loop;

end loop;

--最后一個月的遍歷

v_date.month := to_char(lastMonth);

-- totalDay :=to_date(lastMonth,'yyyy-mm-dd') -to_date(to_char(lastYear)||'-'||to_char(lastMonth)||'-01','yyyy-mm-dd');

totalDay := to_number(to_date(lastDay,'yyyy-mm-dd')-to_date(substr(lastDay,1,7)||'-01','yyyy-mm-dd'))+1;

for id in 1..totalDay loop

v_date.day := substr(lastDay,1,7)||'-'||to_char(id);

pipe row(class_date(v_date.year,v_date.month,v_date.day));

dbms_output.put_line( v_date.day);

end loop;

end if;

--------不同年份

elsif firstYear < lastYear then

----------------------------------------------

--第一個月

v_date.year := to_char(firstYear);

v_date.month := substr(firstDay,6,2);

totalDay :=to_number(substr( to_char(last_day(to_date(firstDay,'yyyy-mm-dd')),'yyyy-mm-dd'),9,2));

for dayId in to_number(substr(firstDay,9,2)) ..totalDay loop

v_date.day := to_char(dayId);

pipe row(class_date(v_date.year,v_date.month,v_date.day));

end loop;

---------------------------------------------------------------

--中間所有月數(shù)的日期添加

totalMonth := to_number( months_between(to_date(lastDay,'yyyy-mm-dd'),to_date(firstDay,'yyyy-mm-dd')))-1;

currentDay := firstDay;

currentDay := substr(currentDay,1,8)||'01';

for monthId in 1..totalMonth loop

--月數(shù)循環(huán)

currentDay:=

to_char(add_months(to_date(currentDay,'yyyy-mm-dd'),1),'yyyy-mm-dd') ;

currentYear := substr(currentDay,1,4);

v_date.year := to_char(substr(trim(currentDay),1,4));

v_date.month := to_char(substr(trim(currentDay),6,2));

--天數(shù)循環(huán)

totalDay := to_number(last_day(to_date(currentDay,'yyyy-mm-dd'))-to_date(currentYear||'-'||substr(currentDay,6,2)||'-01','yyyy-mm-dd'))+1;

for dayId in 1 .. totalDay loop

v_date.day := to_char(dayId);

pipe row(class_date(v_date.year,v_date.month,v_date.day));

dbms_output.put_line( v_date.day);

end loop;

end loop;

-----------------------------------------------------------------------------------

--最后一個月

totalDay := to_number(substr(lastDay,9,2));

v_date.month := to_number(substr(lastDay,6,2));

for dayId in 1 .. totalDay loop

v_date.day := to_char(dayId);

pipe row(class_date(v_date.year,v_date.month,v_date.day));

end loop;

end if;

end minusDay;

更多信息請查看IT技術(shù)專欄

更多信息請查看數(shù)據(jù)庫
易賢網(wǎng)手機網(wǎng)站地址:Oracle數(shù)據(jù)庫日期遍歷功能的實現(xiàn)
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇剩?/div>

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
性欧美xxxx视频在线观看| 国产自产2019最新不卡| 久久综合九九| 国产精品一区二区在线观看| 999亚洲国产精| 欧美大胆人体视频| 亚洲欧洲在线观看| 欧美大片一区二区三区| 136国产福利精品导航| 久久综合福利| 在线观看成人一级片| 久久九九国产精品| 黄色精品一二区| 久久精品欧美日韩| 亚洲国产片色| 欧美日韩免费观看一区三区| 亚洲性感美女99在线| 国产精品久久久久久久久久ktv| 一本一本大道香蕉久在线精品| 欧美日韩国产二区| 正在播放亚洲| 国产精品一区二区三区四区五区| 午夜日韩在线| 一区二区三区在线观看视频| 欧美成人第一页| 日韩午夜精品视频| 国产精品v欧美精品v日韩精品| 亚洲视频 欧洲视频| 国产精品人人做人人爽人人添| 欧美在线免费看| 亚洲区一区二区三区| 国产精品爽黄69| 久久看片网站| 国产一区二区中文字幕免费看| 久久婷婷国产综合精品青草| 亚洲另类黄色| 国产日韩精品一区二区| 免费在线日韩av| 亚洲嫩草精品久久| 亚洲高清三级视频| 欧美日韩综合视频| 久久色中文字幕| 亚洲视频在线播放| 亚洲福利视频专区| 国产日韩精品久久久| 欧美精品三区| 狼人天天伊人久久| 午夜精品久久久久久久久久久久 | 狠狠综合久久| 欧美精品一区二区三区四区| 欧美中文在线观看国产| 91久久精品一区二区别| 国产精品毛片在线看| 欧美国产综合视频| 久久久久久999| 亚洲视频在线一区| 亚洲毛片在线免费观看| 激情五月***国产精品| 欧美国产日本在线| 亚洲视频在线观看| 亚洲精品字幕| 91久久综合| 极品av少妇一区二区| 国产精品一区二区久激情瑜伽| 免费成年人欧美视频| 欧美在线一二三四区| 亚洲欧美日韩在线综合| 一区二区三区久久网| 亚洲高清免费视频| 韩日成人av| 国产日韩欧美精品一区| 农村妇女精品| 免费看亚洲片| 久久蜜桃香蕉精品一区二区三区| 欧美一区二区三区成人| 亚洲欧美日韩一区| 亚洲欧美精品在线观看| 午夜国产欧美理论在线播放| 亚洲欧美视频在线观看| 一区二区三区四区五区精品| 国产一区二区视频在线观看| 国产午夜久久久久| 韩曰欧美视频免费观看| 国产一区二区三区久久悠悠色av| 国产精品欧美久久| 国产精品人人做人人爽| 国产精品热久久久久夜色精品三区| 欧美天堂亚洲电影院在线播放| 欧美日韩无遮挡| 国产精品看片你懂得| 国产精品久久久久一区二区三区 | 欧美一级专区| 欧美一区观看| 免费av成人在线| 欧美日韩在线看| 国产精品推荐精品| 国产揄拍国内精品对白| 国产女同一区二区 | 亚洲伦理网站| 在线亚洲高清视频| 欧美一级在线亚洲天堂| 久久久噜噜噜久久狠狠50岁| 欧美jizzhd精品欧美喷水| 欧美日韩国语| 国产日韩精品一区二区| 精品白丝av| 国产在线一区二区三区四区| 亚洲成色999久久网站| 影音先锋国产精品| 日韩亚洲欧美一区二区三区| 午夜精品久久久久久| 久久久精品网| 欧美日韩中文在线观看| 国产综合网站| 一区二区三区色| 久久精品欧洲| 欧美日韩一区二区高清| 国产一区二区观看| 日韩视频一区二区三区在线播放| 亚洲欧美视频在线| 欧美国产三级| 国产亚洲一二三区| 亚洲视频导航| 欧美成人精品| 国产精品任我爽爆在线播放 | 国产精品亚洲综合色区韩国| 国产精品女人久久久久久| 伊人影院久久| 亚洲综合首页| 欧美日韩视频一区二区| 精品999在线播放| 亚洲一区免费观看| 欧美性大战久久久久久久| 国产亚洲一区二区精品| 99在线精品免费视频九九视| 久久青草久久| 国产精品第一区| 欧美深夜影院| 一区视频在线看| 久久国产高清| 国产深夜精品福利| 亚洲一区在线观看免费观看电影高清| 牛牛影视久久网| 精品动漫3d一区二区三区| 欧美影院成年免费版| 国产精品啊啊啊| 一本色道久久88亚洲综合88| 免费视频久久| 怡红院精品视频| 亚洲一区久久| 欧美日韩免费观看一区三区| 亚洲经典三级| 欧美成人dvd在线视频| 在线观看精品视频| 老司机午夜精品视频在线观看| 黄色日韩网站视频| 91久久精品国产91性色tv| 欧美一级黄色录像| 国产午夜精品福利| 欧美电影美腿模特1979在线看 | 欧美日韩国产在线看| 亚洲一区二区三区精品视频| 国产欧美在线观看一区| 美女主播精品视频一二三四| 99re6这里只有精品| 国产精品推荐精品| 美日韩精品视频| 亚洲一级免费视频| 影音先锋日韩资源| 欧美性猛交视频| 久久人91精品久久久久久不卡| 亚洲精品美女在线观看播放| 国产精品一二一区| 免费亚洲电影| 亚洲自拍偷拍麻豆| 激情成人综合| 国产精品日本精品| 欧美国产综合视频| 亚洲主播在线| 亚洲伦理在线| 在线免费观看日韩欧美| 欧美日韩系列| 久久九九电影| 中文av字幕一区| 国语自产精品视频在线看一大j8| 欧美成人亚洲成人| 欧美在线视频免费观看| av成人福利| 91久久久久| 激情视频一区二区三区| 欧美午夜在线一二页| 欧美国产先锋| 麻豆成人在线播放| 久久国产黑丝| 国产精品美女黄网| 欧美日韩一区二区三区四区五区| 老司机一区二区| 久久久亚洲欧洲日产国码αv| 亚洲欧美日韩另类| 一本色道久久综合亚洲精品不卡 |