数据库

位置:IT落伍者 >> 数据库 >> 浏览文章

oracle日期操作方法


发布日期:2019年12月30日
 
oracle日期操作方法

在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;

               

上一篇:Oracle性能优化:droptable与dbcache

下一篇:ORACLE数据库问题诊断方法 :常见错误篇