知识大全 oracle日期操作方法

Posted 函数

篇首语:事常与人违,事总在人为。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 oracle日期操作方法相关的知识,希望对你有一定的参考价值。

  在oracle中有很多关于日期的函数 如:

   add_months()用于从一个日期值增加或减少一些月份

  date_value:=add_months(date_value number_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 sessiontimezone current_date from dual;

  SESSIONTIMEZONE CURRENT_DA

  

  + : 月

  SQL> alter session set time_zone= :

   /

  会话已更改

  SQL> select sessiontimezone current_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 sessiontimezone current_timestamp from dual;

  SESSIONTIMEZONE CURRENT_TIMESTAMP

  

  + : 月 上午 + :

  

  SQL> alter session set time_zone= :

   /

  会话已更改

  SQL> select sessiontimezone current_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 localtimestamp current_timestamp from dual;

  LOCALTIMESTAMP CURRENT_TIMESTAMP

  

   月 月 下午 + :

  下午

  SQL> alter session set time_zone= : ;

  会话已更改

  SQL> select localtimestamp to_char(sysdate DD MM YYYY HH:MI:SS AM ) SYSDATE from dual;

  LOCALTIMESTAMP SYSDATE

  

   月 : : 下午

  下午

  SQL>

   months_beeen()判断两个日期之间的月份数量

  number_value:=months_beeen(date_value date_value)

  SQL> select months_beeen(sysdate date ) from dual;

  MONTHS_BEEEN(SYSDATE DATE )

  

  

  SQL> select months_beeen(sysdate date ) from dual;

  MONTHS_BEEEN(SYSDATE DATE )

  

  

  SQL>

   next_day()给定一个日期值 返回由第二个参数指出的日子第一次出现在的日期值(应返回相应日子的名称字符串)

  说明:

  单行日期函数

  单行日期函数操作data数据类型 绝大多数都有data数据类型的参数 绝大多数返回的也是data数据类型的值

  add_months( )

  返回日期d加上i个月后的结果 i可以使任意整数 如果i是一个小数 那么数据库将隐式的他转换成整数 将会截去小数点后面的部分

  last_day()

  函数返回包含日期d的月份的最后一天

  months_beeen( )

  返回d 和d 之间月的数目 如果d 和d 的日的日期都相同 或者都使该月的最后一天 那么将返回一个整数 否则会返回的结果将包含一个分数

  new_time( )

  d 是一个日期数据类型 当时区tz 中的日期和时间是d时 返回时区tz 中的日期和时间 tz 和tz 时字符串

  next_day( )

  返回日期d后由dow给出的条件的第一天 dow使用当前会话中给出的语言指定了一周中的某一天 返回的时间分量与d的时间分量相同

  select next_day( jan monday ) st monday next_day( nov tuesday )+ nd tuesday ) from dual; st monday nd tuesday jan nov

  round([ ])

  将日期d按照fmt指定的格式舍入 fmt为字符串

  syadate

  函数没有参数 返回当前日期和时间

  trunc([ ])

  返回由fmt指定的单位的日期d

  单行转换函数

  单行转换函数用于操作多数据类型 在数据类型之间进行转换

  chartorwid()

  c 使一个字符串 函数将c转换为rwid数据类型

  select test_id from test_case where rowid=chartorwid( aaaa saacaaaaliaaa )

  convert( [ ])

  c尾字符串 dset sset是两个字符集 函数将字符串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格式显示的c nlsparm表示使用的语言 函数将字符串c转换成date数据类型

  to_multi_byte()

  c表示一个字符串 函数将c的担子截字符转换成多字节字符

  to_number([ [ )

  c表示字符串 fmt表示一个特殊格式的字符串 函数返回值按照fmt指定的格式显示 nlsparm表示语言 函数将返回c代表的数字

  to_single_byte()

  将字符串c中得多字节字符转化成等价的单字节字符 该函数仅当数据库字符集同时包含单字节和多字节字符时才使用

  Oracle关于时间/日期的操作

   日期时间间隔操作

  当前时间减去 分钟的时间

  select sysdate sysdate interval MINUTE from dual

  当前时间减去 小时的时间

  select sysdate interval hour from dual

  当前时间减去 天的时间

  select sysdate interval day from dual

  当前时间减去 月的时间

  select sysdate sysdate interval month from dual

  当前时间减去 年的时间

  select sysdate sysdate interval year from dual

  时间间隔乘以一个数字

  select sysdate sysdate *interval hour from dual

   日期到字符操作

  select sysdate to_char(sysdate yyyy mm dd hh :mi:ss ) from dual

  select sysdate to_char(sysdate yyyy mm dd hh:mi:ss ) from dual

  select sysdate to_char(sysdate yyyy ddd hh:mi:ss ) from dual

  select sysdate to_char(sysdate yyyy mm iw d hh:mi:ss ) from dual

  参考oracle的相关关文档(ORACLE DOC/SERVER /A /SQL_ELEMENTS HTM# )

   字符到日期操作

  select to_date( : : yyyy mm dd 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( ) DD MON YYYY 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_objects object_name%type;

  l_start number default dbms_utility get_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_output put_line

  ( round( (dbms_utility get_time l_start)/ ) ||

   seconds );

cha138/Article/program/Oracle/201311/17078

相关参考

知识大全 Oracle日期时间函数的应用

Oracle日期时间函数的应用  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  转换函数  与da

知识大全 Oracle中一个日期查找的误区

Oracle中一个日期查找的误区  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! &nbs

知识大全 从Unix到Oracle的日期转换

从Unix到Oracle的日期转换  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  CREATEO

知识大全 oracle日期时间模糊查询的方法

  思路是先将oracle中时间字段转化成字段串然后与字符串模糊查询  如下  StringstrSQLSearch=SELECT*FROM+objConfigDBgetTableName()+WHE

知识大全 在Oracle中实现各种日期处理完全版

在Oracle中实现各种日期处理完全版  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  TO_DA

知识大全 oracle带时分秒日期的比较

  oracle中不带时分秒的字符串to_date转换时间后与带时分秒的date型字段做带等值的比较(>=<==)时由于字符串不带时分秒所以转换后时分秒默认为::oracle中比较date

知识大全 Oracle基本数据类型存储格式浅析—日期类型(1)

Oracle基本数据类型存储格式浅析—日期类型(1)  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

知识大全 Oracle基本数据类型存储格式浅析—日期类型(3)

Oracle基本数据类型存储格式浅析—日期类型(3)  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

知识大全 Oracle中的格式掩码、货币和日期格式

Oracle中的格式掩码、货币和日期格式  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  toch

知识大全 Oracle中几个关于日期方面的SQL实例

Oracle中几个关于日期方面的SQL实例  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  №:取