在oracle中有很多关于日期的函数如:
add_months()用于从一个日期值增加或减少一些月份
date_value:=add_months(date_valuenumber_of_months)
例:
SQL> select add_months(sysdate) Next Year from dual;
Next Year
月
SQL> select add_months(sysdate) Last Year from dual;
Last Year
月
SQL>
current_date()返回当前会放时区中的当前日期
date_value:=current_date
SQL> column sessiontimezone for a
SQL> select sessiontimezonecurrent_date from dual;
SESSIONTIMEZONE CURRENT_DA
+: 月
SQL> alter session set time_zone=:
/
会话已更改
SQL> select sessiontimezonecurrent_timestamp from dual;
SESSIONTIMEZONE CURRENT_TIMESTAMP
: 月 下午 :
SQL>
current_timestamp()以timestamp with time zone数据类型返回当前会放时区中的当前日期
timestamp_with_time_zone_value:=current_timestamp([timestamp_precision])
SQL> column sessiontimezone for a
SQL> column current_timestamp format a
SQL> select sessiontimezonecurrent_timestamp from dual;
SESSIONTIMEZONE CURRENT_TIMESTAMP
+: 月 上午 +:
SQL> alter session set time_zone=:
/
会话已更改
SQL> select sessiontimezonecurrent_timestamp from dual;
SESSIONTIMEZONE CURRENT_TIMESTAMP
: 月 下午 :
SQL>
dbtimezone()返回时区
varchar_value:=dbtimezone
SQL> select dbtimezone from dual;
DBTIME
:
SQL>
extract()找出日期或间隔值的字段值
date_value:=extract(date_field from [datetime_value|interval_value])
SQL> select extract(month from sysdate) This Month from dual;
This Month
SQL> select extract(year from add_months(sysdate)) Years Out from dual;
Years Out
SQL>
last_day()返回包含了日期参数的月份的最后一天的日期
date_value:=last_day(date_value)
SQL> select last_day(date) Leap Yr? from dual;
Leap Yr?
月
SQL> select last_day(sysdate) Last day of this month from dual;
Last day o
月
SQL>
localtimestamp()返回会话中的日期和时间
timestamp_value:=localtimestamp
SQL> column localtimestamp format a
SQL> select localtimestamp from dual;
LOCALTIMESTAMP
月
下午
SQL> select localtimestampcurrent_timestamp from dual;
LOCALTIMESTAMP CURRENT_TIMESTAMP
月 月 下午 +:
下午
SQL> alter session set time_zone=:;
会话已更改
SQL> select localtimestampto_char(sysdateDDMMYYYY HH:MI:SS AM) SYSDATE from dual;
LOCALTIMESTAMP SYSDATE
月 :: 下午
下午
SQL>
months_between()判断两个日期之间的月份数量
number_value:=months_between(date_valuedate_value)
SQL> select months_between(sysdatedate) from dual;
MONTHS_BETWEEN(SYSDATEDATE)
SQL> select months_between(sysdatedate) from dual;
MONTHS_BETWEEN(SYSDATEDATE)
SQL>
next_day()给定一个日期值返回由第二个参数指出的日子第一次出现在的日期值(应返回相应日子的名称字符串)
说明:
单行日期函数
单行日期函数操作data数据类型绝大多数都有data数据类型的参数绝大多数返回的也是data数据类型的值
add_months()
返回日期d加上i个月后的结果i可以使任意整数如果i是一个小数那么数据库将隐式的他转换成整数将会截去小数点后面的部分
last_day()
函数返回包含日期d的月份的最后一天
months_between()
返回d和d之间月的数目如果d和d的日的日期都相同或者都使该月的最后一天那么将返回一个整数否则会返回的结果将包含一个分数
new_time()
d是一个日期数据类型当时区tz中的日期和时间是d时返回时区tz中的日期和时间tz和tz时字符串
next_day()
返回日期d后由dow给出的条件的第一天dow使用当前会话中给出的语言指定了一周中的某一天返回的时间分量与d的时间分量相同
select next_day(janmonday) st mondaynext_day(novtuesday)+ nd tuesday) from dual;st monday nd tuesdayjan nov
round([])
将日期d按照fmt指定的格式捨入fmt为字符串
syadate
函数没有参数返回当前日期和时间
trunc([])
返回由fmt指定的单位的日期d
单行转换函数
单行转换函数用于操作多数据类型在数据类型之间进行转换
chartorwid()
c 使一个字符串函数将c转换为rwid数据类型
select test_id from test_case where rowid=chartorwid(aaaasaacaaaaliaaa)
convert([])
c尾字符串dsetsset是两个字符集函数将字符串c由sset字符集转换为dset字符集sset的缺省设置为数据库的字符集
hextoraw()
x为进制的字符串函数将进制的x转换为raw数据类型
rawtohex()
x是raw数据类型字符串函数将raw数据类转换为进制的数据类型
rowidtochar()
函数将rowid数据类型转换为char数据类型
to_char([[)
x是一个data或number数据类型函数将x转换成fmt指定格式的char数据类型如果x为日期nlsparm=nls_date_language 控制返回的月份和日份所使用的语言如果x为数字nlsparm=nls_numeric_characters 用来指定小数位和千分位的分隔符以及货币符号
nls_numeric_characters =dg nls_currency=string
to_date([[)
c表示字符串fmt表示一种特殊格式的字符串返回按照fmt格式显示的cnlsparm表示使用的语言函数将字符串c转换成date数据类型
to_multi_byte()
c表示一个字符串函数将c的担子截字符转换成多字节字符
to_number([[)
c表示字符串fmt表示一个特殊格式的字符串函数返回值按照fmt指定的格式显示nlsparm表示语言函数将返回c代表的数字
to_single_byte()
将字符串c中得多字节字符转化成等价的单字节字符该函数仅当数据库字符集同时包含单字节和多字节字符时才使用
Oracle关于时间/日期的操作
日期时间间隔操作
当前时间减去分钟的时间
select sysdatesysdate interval MINUTE from dual
当前时间减去小时的时间
select sysdate interval hour from dual
当前时间减去天的时间
select sysdate interval day from dual
当前时间减去月的时间
select sysdatesysdate interval month from dual
当前时间减去年的时间
select sysdatesysdate interval year from dual
时间间隔乘以一个数字
select sysdatesysdate *interval hour from dual
日期到字符操作
select sysdateto_char(sysdateyyyymmdd hh:mi:ss) from dual
select sysdateto_char(sysdateyyyymmdd hh:mi:ss) from dual
select sysdateto_char(sysdateyyyyddd hh:mi:ss) from dual
select sysdateto_char(sysdateyyyymm iwd hh:mi:ss) from dual
参考oracle的相关关文档(ORACLEDOC/SERVER/A/SQL_ELEMENTSHTM#)
字符到日期操作
select to_date( ::yyyymmdd hh:mi:ss) from dual
具体用法和上面的to_char差不多
trunk/ ROUND函数的使用
select trunc(sysdate YEAR) from dual
select trunc(sysdate ) from dual
select to_char(trunc(sysdate YYYY)YYYY) from dual
oracle有毫秒级的数据类型
返回当前时间 年月日小时分秒毫秒
select to_char(current_timestamp()DDMONYYYY HH:MI:SSxFF) from dual;
返回当前 时间的秒毫秒可以指定秒后面的精度(最大=)
select to_char(current_timestamp()MI:SSxFF) from dual;
计算程序运行的时间(ms)
declare
type rc is ref cursor;
l_rc rc;
l_dummy all_objectsobject_name%type;
l_start number default dbms_utilityget_time;
begin
for I in
loop
open l_rc for
select object_name from all_objects ||
where object_id = || i;
fetch l_rc into l_dummy;
close l_rc;
end loop;
dbms_outputput_line
( round( (dbms_utilityget_timel_start)/ ) ||
seconds );
end;