文档详情

第8章 Oracle中的日期型.ppt

发布:2017-08-23约3.05千字共15页下载文档
文本预览下载声明
第8章 Oracle中的日期型及处理方法 Oracle中提供了日期型来处理日期相关的应用。其中,最常用的类型为date和timestamp。本章将讲述日期类型的基本信息及处理方法,主要内容包括: 日期型简介 日期型函数 通过本章的学习,读者可以了解Oracle中日期型的基本应用。 8.1 Oracle中的日期型 Oracle中的date类型实际包含了以下信息: Century:世纪信息; Year:年份信息; Month:月份信息; Day:天数信息; Hour:小时信息; Minute:分钟信息; Second:秒数信息。 除此之外,Oracle还提供了timestamp(时间戳)类型。该类型用于表征更加精确的时间,精确度可以达到毫秒级。 8.2 Oracle中的日期处理 Oracle提供了丰富的函数来处理日期,本节将详细讲述这些函数的用法。 8.2.1 获得当期日期——sysdate函数 该函数用法返回当前日期,如下所示。 SQL select sysdate from dual; SYSDATE ------------------------------ 2010-4-4 12:06:25 在执行结果中可以看到,当期日期信息中包含了年、月、日、时、分、秒等信息。 8.2.2 为日期加上特定月份——add_months()函数 对于一个日期型来说,一个常见应用为添加固定月数。例如,劳动法规定,员工自递交辞职报告一个月之后将自动离职,那么,可以利用add_months()函数自动计算员工的离职日期。 SQL select add_months(sysdate, 1) new_date from dual; NEW_DATE ------------------------------ 2010-5-4 12:22:34 8.2.3 返回特定日期所在月的最后一天——last_day()函数 last_day()函数可以用于返回某个日期所在月份的最后一天,返回值同样为一个日期型。 SQL select last_day(to_date(2010-2-28, YYYY-MM-DD)) new_date from dual; NEW_DATE ------------------------------ 2010-2-28 SQL select last_day(to_date(2000-2-28, YYYY-MM-DD)) new_date from dual; NEW_DATE ------------------------------ 2000-2-29 8.2.4 返回两个日期所差的月数——months_between ()函数 months_between()函数用于返回两个日期相减获得的月数。该函数的返回值并不一定为整数,如下所示。 SQL select months_between(to_date(2010-4-4, YYYY-MM-DD), to_date(2010-2-6, YYYY-MM-DD)) 2 as new_date from dual; NEW_DATE ------------------------------ 1.93548387096774 8.2.5 返回特定日期之后的一周之内的日期——next_day()函数 next_day()函数用于获得特定日期之后的一个星期之内的日期。例如,2010-4-4是星期日,那么,为了获得紧随其后的第一个星期一,可以利用如下语句。 SQL select next_day(to_date(2010-4-4, yyyy-mm-dd), 2) new_date from dual; NEW_DATE ----------- 2010-4-5 8.2.6 截取日期——trunc()函数 trunc()函数不仅可以截取数字,而且可以截取日期,其工作原理与截取数字非常相似。其使用语法如下所示。 trunc(日期, 截取格式) 为了使用该函数,不仅需要指定日期原始值,而且要指定截取格式——即截取到日期的哪个部分。 SQL select trunc(sysdate, DD) new_date from dual; NEW_DATE ------------------------------ 2010-4-5 8.2.7 返回当前会话时区的当前日期——current_date()函数 current_date()函数用于返回当前时区下的当前日期,我们可以结合当前时区来查看current_date()函数的使用。 SQL select sessiontimezone, to_char(current_date, yyyy-m
显示全部
相似文档