在Oracle中,如何检测夏令时开始/结束的日期?
发布时间:2020-12-12 13:16:01 所属栏目:百科 来源:网络整理
导读:在Oracle中是否有办法选择夏令时切换到我的语言环境的日期? 模糊地等同于此的东西会很好: SELECT CHANGEOVER_DATEFROM SOME_SYSTEM_TABLEWHERE DATE_TYPE = 'DAYLIGHT_SAVINGS_CHANGEOVER' AND TO_CHAR(CHANGEOVER_DATE,'YYYY') = TO_CHAR(SYSDATE,'YYYY')
在Oracle中是否有办法选择夏令时切换到我的语言环境的日期?
模糊地等同于此的东西会很好: SELECT CHANGEOVER_DATE FROM SOME_SYSTEM_TABLE WHERE DATE_TYPE = 'DAYLIGHT_SAVINGS_CHANGEOVER' AND TO_CHAR(CHANGEOVER_DATE,'YYYY') = TO_CHAR(SYSDATE,'YYYY'); -- in the current year 编辑:我希望找到一个解决方案,在国会调整DST法律时不需要改变,就像他们在2007年所做的那样.但是,已发布的解决方案可行. 解决方法我们使用以下两个函数来计算任何给定年份的开始和结束日期(2007年后,美国).Function DaylightSavingTimeStart (p_Date IN Date) Return Date Is v_Date Date; v_LoopIndex Integer; Begin --Set the date to the 8th day of March which will effectively skip the first Sunday. v_Date := to_date('03/08/' || to_char(p_Date,'YYYY') || '02:00:00 AM','MM/DD/YYYY HH:MI:SS PM'); --Advance to the second Sunday. FOR v_LoopIndex IN 0..6 LOOP If (RTRIM(to_char(v_Date + v_LoopIndex,'DAY')) = 'SUNDAY') Then Return v_Date + v_LoopIndex; End If; END LOOP; End; Function DaylightSavingTimeEnd (p_Date IN Date) Return Date Is v_Date Date; v_LoopIndex Integer; Begin --Set Date to the first of November this year v_Date := to_date('11/01/' || to_char(p_Date,'MM/DD/YYYY HH:MI:SS PM'); --Advance to the first Sunday FOR v_LoopIndex IN 0..6 LOOP If (RTRIM(to_char(v_Date + v_LoopIndex,'DAY')) = 'SUNDAY') Then Return v_Date + v_LoopIndex; End If; END LOOP; End; 可能有一种更简单的方法,但这些对我们有用.当然,此查询不知道是否在您所在的位置观察到夏令时.为此你需要location data. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |