设为首页 收藏本站
查看: 428|回复: 0

[经验分享] oracle中日期处理方法 汇总

[复制链接]

尚未签到

发表于 2016-7-30 22:12:16 | 显示全部楼层 |阅读模式

Day:
ddnumber12
dyabbreviatedfri
dayspelledoutfriday
ddspthspelledout,ordinaltwelfth
Month:
mmnumber03
monabbreviatedmar
monthspelledoutmarch
Year:
yytwodigits98
yyyyfourdigits1998


  24小时格式下时间范围为:0:00:00-23:59:59....

  12小时格式下时间范围为:1:00:00-12:59:59....


  1.日期和字符转换函数用法(to_date,to_char)

  2.selectto_char(to_date(222,'J'),'Jsp')fromdual

  显示TwoHundredTwenty-Two



  3.求某天是星期几selectto_char(to_date('2002-08-26','yyyy-mm-dd'),'day')fromdual;
星期一
selectto_char(to_date('2002-08-26','yyyy-mm-dd'),'day','NLS_DATE_LANGUAGE=American')fromdual;
monday




  设置日期语言ALTERSESSIONSETNLS_DATE_LANGUAGE='AMERICAN';


  也可以这样TO_DATE('2002-08-26','YYYY-mm-dd','NLS_DATE_LANGUAGE=American')


网管联盟bitsCN@com


  4.两个日期间的天数selectfloor(sysdate-to_date('20020405','yyyymmdd'))fromdual;




  5.时间为null的用法selectid,active_datefromtable1
UNION
select1,TO_DATE(null)fromdual;





  注意要用TO_DATE(null)

  6.a_datebetweento_date('20011201','yyyymmdd')andto_date('20011231','yyyymmdd')

  那么12月31号中午12点之后和12月1号的12点之前是不包含在这个范围之内的。

  所以,当时间需要精确的时候,觉得to_char还是必要的

  7.日期格式冲突问题




  输入的格式要看你安装的ORACLE字符集的类型,比如:US7ASCII,date格式的类型就是:'01-Jan-01'
altersystemsetNLS_DATE_LANGUAGE=American
altersessionsetNLS_DATE_LANGUAGE=American


  或者在to_date中写selectto_char(to_date('2002-08-26','yyyy-mm-dd'),'day','NLS_DATE_LANGUAGE=American')fromdual;




  注意我这只是举了NLS_DATE_LANGUAGE,当然还有很多,



  可查看select*fromnls_session_parameters
select*fromV$NLS_PARAMETERS


 8.selectcount(*)
from(selectrownum-1rnum
fromall_objects
whererownum<=to_date('2002-02-28','yyyy-mm-dd')-to_date('2002-
02-01','yyyy-mm-dd')+1
)
whereto_char(to_date('2002-02-01','yyyy-mm-dd')+rnum-1,'D')
not
in('1','7')

  查找2002-02-28至2002-02-01间除星期一和七的天数

  在前后分别调用DBMS_UTILITY.GET_TIME,让后将结果相减(得到的是1/100秒,而不是毫秒).



selectmonths_between(to_date('01-31-1999','MM-DD-YYYY'),
to_date('12-31-1998','MM-DD-YYYY'))"MONTHS"FROMDUAL;
1

selectmonths_between(to_date('02-01-1999','MM-DD-YYYY'),
to_date('12-31-1998','MM-DD-YYYY'))"MONTHS"FROMDUAL;

1.03225806451613


  10.Next_day的用法Next_day(date,day)

Monday-Sunday,forformatcodeDAY
Mon-Sun,forformatcodeDY
1-7,forformatcodeD





  11.selectto_char(sysdate,'hh:mi:ss')TIMEfromall_objects

  注意:第一条记录的TIME与最后一行是一样的

  可以建立一个函数来处理这个问题createorreplacefunctionsys_datereturndateis
begin
returnsysdate;
end;

selectto_char(sys_date,'hh:mi:ss')fromall_objects;


网管u家u.bitsCN.com

  12.获得小时数SELECTEXTRACT(HOURFROMTIMESTAMP'2001-02-162:38:40')fromoffer
SQL>selectsysdate,to_char(sysdate,'hh')fromdual;

SYSDATETO_CHAR(SYSDATE,'HH')
-----------------------------------------
2003-10-1319:35:2107

SQL>selectsysdate,to_char(sysdate,'hh24')fromdual;

SYSDATETO_CHAR(SYSDATE,'HH24')
-------------------------------------------
2003-10-1319:35:2119



  获取年月日与此类似

  13.年月日的处理selectolder_date,
newer_date,
years,
months,
abs(
trunc(
newer_date-
add_months(older_date,years*12+months)
)
)days
from(select
trunc(months_between(newer_date,older_date)/12)YEARS,
mod(trunc(months_between(newer_date,older_date)),
12)MONTHS,
newer_date,
older_date
from(selecthiredateolder_date,
add_months(hiredate,rownum)+rownumnewer_date
fromemp)
)


  14.处理月份天数不定的办法selectto_char(add_months(last_day(sysdate)+1,-2),'yyyymmdd'),last_day(sysdate)fromdual


  15.找出今年的天数selectadd_months(trunc(sysdate,'year'),12)-trunc(sysdate,'year')fromdual


  闰年的处理方法to_char(last_day(to_date('02'||:year,'mmyyyy')),'dd')

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-251418-1-1.html 上篇帖子: 原创:oracle 子查询介绍 (七) 下篇帖子: oracle 行迁移与行链接(1)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表