`
Rooock
  • 浏览: 36810 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Oracle的一些关于时间的函数

阅读更多
--  语句级一致性事务或读已提交事务(默认)
set transaction isolation read committed;

--  只读事务
set transaction read only;

--  事务级一致性事务或顺序事务
set transaction isolation level serializable;

--  设置该事务使用一个回退段
set transaction use rollback segment rollback_segment_name;

--  提交事务
commit;

--  更改日期格式
alter session set nls_date_format = 'yyyy-mm-dd hh24:mi:ss';


--  查询当前数据库的日期时间
SQL> select sysdate "    看看能有多精准    " from dual;

    看看能有多精准
----------------------
2008-11-17 14:59:45


--  查询当前会话的日期
SQL> select current_date "      当前日期      " from dual;

      当前日期
--------------------
2008-11-17 11:53:20


--  查询当前会话的日期时间,带精度.精度范围为0~9,默认是6. CURRENT_TIMESTAMP[(d)]
SQL> select current_timestamp(6) from dual;

CURRENT_TIMESTAMP(6)
--------------------------------------------------------------------------------
17-11月-08 11.52.11.676615 上午 +08:00


--  查询日期时间d中指定的部分c. EXTRACT(c, FROM d)
SQL> select sysdate "      当前日期      ", extract(year from sysdate) year, extract(month from sysdate) month, extract(day from sysdate) day from dual;

      当前日期              YEAR      MONTH        DAY
-------------------- ---------- ---------- ----------
2008-11-17 12:02:02        2008         11         17


--  查询日期d所在月份的最后一天
SQL> select last_day(sysdate) lastDay from dual;

LASTDAY
-----------
2008-11-30


--  查询当前会话时区的日期时间.带精度.精度范围为0~9,默认是6. LOCALTIMESTAMP[(d)]
SQL> select localtimestamp(6) from dual;

LOCALTIMESTAMP(6)
--------------------------------------------------------------------------------
17-11月-08 02.30.55.921204 下午


--  查询日期d1和d2之间相差的月数. 如果d1<d2,返回负值; 如果d1和d2天数相同或都是月底,则返回整数; 否则Oracle以每月31天计算结果的小数部分.
SQL> select months_between(sysdate, sysdate-31) "相差月数" from dual;

      相差月数
----------
         1


--  查询日期d后下一个c.c是字符串,表示当前会话语言表示的一周的某一天的全称.
SQL> select sysdate 当前日期, next_day(sysdate, '星期日') 新日期 from dual;

当前日期     新日期
----------- -----------
2008-11-17  2008-11-23


--  对日期进行四舍五入
SQL> select sysdate 当前日期, round(sysdate, 'day') 处理后的日, round(sysdate, 'month') 处理后的月, round(sysdate, 'year') 处理后的年 from dual;

当前日期     处理后的日   处理后的月   处理后的年
----------- ----------- ----------- -----------
2008-11-17  2008-11-16  2008-12-1   2009-1-1


--  对日期进行截断
SQL> select sysdate 当前日期, trunc(sysdate, 'year') 处理后的年, trunc(sysdate, 'month') 处理后的月, trunc(sysdate, 'day') 处理后的日 from dual;

当前日期     处理后的年   处理后的月   处理后的日
----------- ----------- ----------- -----------
2008-11-17  2008-1-1    2008-11-1   2008-11-16


--  查询数据库时区偏移量
SQL> select sessiontimezone from dual;

SESSIONTIMEZONE
---------------------------------------------------------------------------
+08:00


--  查询数据库所在的时区
SQL> select dbtimezone from dual;

DBTIMEZONE
----------
+08:00


--  查询时区名tz指定的时区与格林尼治相比的时区偏差
SQL> select tz_offset(dbtimezone), tz_offset('Europe/London') from dual;

TZ_OFFSET(DBTIMEZONE) TZ_OFFSET('EUROPE/LONDON')
--------------------- --------------------------
+08:00                +00:00


--  返回当前数据库的一个TIMESTAMP WITH TIME ZONE类型的日期时间
SQL> select systimestamp from dual;

SYSTIMESTAMP
--------------------------------------------------------------------------------
17-11月-08 02.56.13.115110 下午 +08:00


--  将字符串c转变为ascii字符串. ASCIISTR(c)
SQL> select asciistr('abc#中国*ABC') from dual;

ASCIISTR('ABC#中国*ABC')
------------------------
abc#\4E2D\56FD*ABC


--  将二进制转为十进制. BIN_TO_NUM(n1, n2, n3, ...)
SQL> select bin_to_num(1, 1, 0, 1) from dual;

BIN_TO_NUM(1,1,0,1)
-------------------
                 13


--  将表达式c转换为数据类型t.
SQL> select sysdate, cast(sysdate as varchar2(25)) from dual;

SYSDATE     CAST(SYSDATEASVARCHAR2(25))
----------- ---------------------------
2008-11-17  17-11月-08



--  把数字n转化成c指定的INTERVAL DAY TO SECOND类型的数据
SQL> select sysdate "    当前时间    ", sysdate + numtodsinterval(30, 'minute') "    30分钟后    ", sysdate + numtodsinterval(2, 'hour') "     两小时后   "from dual;

    当前时间          30分钟后          两小时后
---------------- ---------------- ----------------
2008-11-17 15:51 2008-11-17 16:21 2008-11-17 17:51


--  把数字n转化为c指定的INTERVAL YEAR TO SECOND类型的数据
SQL> select sysdate "    当前时间    ", sysdate + numtoyminterval(2, 'year') "    2年后    ", sysdate + numtoyminterval(6, 'month') "     6个月后   " from dual;

    当前时间          2年后          6个月后
---------------- ------------- ---------------
2008-11-17 16:07 2010-11-17 16 2009-5-17 16:07


--  返回将x按fmt格式转化后的字符串. TO_CAHR(x[, fmt])
SQL> select to_char(sysdate, 'yyyy-mm-dd hh:mi:ss') 当前时间 from dual;

当前时间
-------------------
2008-11-17 04:12:16

SQL> select to_char(123.456, '9.99EEEE') num1, to_char(123.456, '9999.90') from dual;

NUM1       TO_CHAR(123.456,'9999.90')
---------- --------------------------
  1.23E+02   123.46


--  将符合fmt指定的特定日期格式的字符串c转化成DATE类型的数据
SQL> select to_date('20-11月-2008', 'dd-mon-yyyy') 当前时间 from dual;

当前时间
-----------------------------
2008-11-20


--  将符合特定格式的字符串转化成INTERVAL DAY TO SECOND类型的数据
SQL> select sysdate "      当前时间      ", sysdate + to_dsinterval('030 12:00:00') "     30.5天后     " from dual;

      当前时间             30.5天后
-------------------- ------------------
2008-11-17 16:45:38  2008-12-18 4:45:38


--  将符合fmt指定的数字格式的字符串c转化成数字类型的数据
SQL> select to_number('RMB1234567.89', 'L99999999D99') 金额 from dual;

        金额
----------
1234567.89


--  返回字符串c对应的UNICODE字符
SQL> select unistr('\00D6') unicode_1, unistr('ca\00D6on') unicode_2 from dual;

UNICODE_1 UNICODE_2
--------- ----------
Ö         caÖon


--  返回e1, e2, e3, ..., en中最大的数. 以e1的数据类型为准. GREATEST(e1, e2, ..., en)
SQL> select greatest('101', 10, 100) from dual;

GREATEST('101',10,100)
----------------------
101


--  NVL(a, b): 当a是NULL, 则返回b, 否则返回a
SQL> select nvl(null, 0), nvl('null', 0), nvl(null, null) from dual;

NVL(NULL,0) NVL('NULL',0) NVL(NULL,NULL)
----------- ------------- --------------
          0 null   



--  NVL2(a, b, c): 当a不是NULL, 则返回b, 否则返回c
SQL> select nvl2(null, 'b', 3), nvl2('a', 'b', 'c') from dual;

NVL2(NULL,'B',3) NVL2('A','B','C')
---------------- -----------------
3                b

分享到:
评论

相关推荐

    简单的oracle 时间比较函数

    简单的oracle 时间比较函数,自己在网上找到并加以整理出来。

    oracle日期时间判断函数

    Oracle提供了丰富的日期时间函数,用于处理和分析日期时间数据。针对标题"oracle日期时间判断函数"和描述中提到的内容,我们可以深入探讨两个关键的函数,它们主要用于判断字符串是否可以转换为合法的日期时间格式。...

    oracle自定义日期函数

    Oracle 日期处理函数是数据库管理系统中非常重要的一部分,最近看到有人在做 T-SQL 与 PL/SQL 的转化,问了些有关时间函数的处理。在 PL/SQL 中,Oracle 提供了其他的方法来处理日期函数,例如 DATE_ADD 函数。在 T-...

    ORACLE日期时间函数大全

    ORACLE日期时间函数大全

    oracle 函数大全 参考函数 手册 速查 chm格式

    3. 日期时间函数:如SYSDATE(获取当前系统日期)、ADD_MONTHS(添加月份)、EXTRACT(提取日期部分)等,便于对日期和时间进行操作。 4. 转换函数:如TO_CHAR(字符串转换为日期或数字)、TO_DATE(日期转换为字符...

    oracle数据库时间函数

    Oracle 数据库中并没有直接使用 `CONVERT` 函数来处理日期和时间的方式,这个函数在 SQL Server 中被用来进行数据类型的转换,特别是日期和时间类型的转换。然而,Oracle 提供了类似的功能,如 `TO_DATE` 和 `TO_...

    Oracle中的分析函数详解

    其中,Oracle的分析函数是其强大的特性之一,它允许用户在单个SQL查询中执行复杂的分析操作,而无需使用子查询或者自连接。这篇文档将深入探讨Oracle中的分析函数,帮助你更好地理解和利用这一功能。 一、什么是...

    ORACLE 关于时间函数to_date 的运用

    在Oracle数据库中,时间函数是处理日期和时间数据的关键工具之一。其中,`TO_DATE`函数尤为突出,它被广泛用于将字符串转换为日期格式,这对于数据查询、数据分析以及各种与时间相关的操作至关重要。以下是对`TO_...

    oracle最常用的函数或方法总结

    3. **日期时间函数** - `SYSDATE`:获取当前系统日期和时间。 - `ADD_MONTHS()`:向日期添加指定的月数。 - `EXTRACT()`:从日期时间值中提取部分(如年、月、日、小时)。 - `MONTHS_BETWEEN()`:计算两个日期...

    oracle函数大全(CHM格式).rar

    Oracle数据库中的函数可以分为多种类型,包括内置函数、数学函数、字符串函数、日期时间函数、转换函数、系统信息函数等。例如: 1. **内置函数**:如`SYSDATE`用于获取当前系统日期,`USER`获取当前登录用户的...

    Oracle常用日期型函数

    Oracle常用日期型函数,大家经常想用的,又不想记得。现在,给你一个方便的资源

    oracle日期函数全面总结

    Oracle数据库系统中,日期函数是进行时间数据处理的关键工具,对于数据库管理员和开发人员来说,理解和熟练使用这些函数至关重要。本篇文章将全面总结Oracle中的日期函数,帮助你解决日常工作中遇到的各种日期处理...

    oracle时间函数

    ### Oracle时间函数详解 在Oracle数据库中,时间函数是一组非常重要的工具,它们可以帮助我们处理日期和时间数据,实现各种日期计算的需求。本文将重点介绍三个实用的时间函数:`TO_NUMBER()`, `TO_CHAR()` 以及 `...

    postgresql 兼容 oracle 函数

    1. **日期和时间函数**:Oracle中的ADD_MONTHS、LAST_DAY、NEXT_DAY等在orafce中都有对应的实现,帮助用户处理日期和时间数据。 2. **字符串函数**:诸如 INITCAP、SUBSTR、INSTR等在PostgreSQL中也有相应的实现,...

    Oracle 递归函数介绍

    3. 提高开发效率:递归函数可以提高开发效率,减少开发时间。 但是,递归函数也存在一些局限性,例如: 1. 性能问题:递归函数可能会导致性能问题,特别是在大规模数据集的情况下。 2. stack overflow 问题:递归...

    oracle数据仓库分析函数汇总

    Oracle数据仓库分析函数是数据库查询和分析中的重要工具,尤其对于商业智能(BI)和数据仓库项目来说,它们能够提供深度的数据洞察。本资源“oracle数据仓库分析函数汇总”聚焦于Oracle数据库中的分析函数,尤其是与...

    Oracle与Informix函数比较.doc

    Oracle 和 Informix 都提供了日期和时间函数来处理日期和时间数据。这些函数可以用来获取当前日期和时间、将日期字符串转换为日期类型、获取指定日期的月份、星期几等。 1. 获取当前日期和时间:Informix 中的 ...

    Oracle中实现datadiff函数

    然而,在Oracle中我们可以通过自定义函数的方式实现类似的功能,即计算两个日期之间的时间差。 #### 实现方法 为了在Oracle中模拟`DATEDIFF`功能,我们可以创建一个用户定义的函数。下面将详细介绍如何创建和使用...

    Oracle日期函数练习

    Oracle 日期函数是 Oracle 数据库中的一组功能强大且广泛使用的函数,它们可以对日期进行各种操作和计算,本次练习涵盖了 Oracle 中常用的日期函数,包括获取当前系统时间、对日期的月进行加减、获取给定日期所在月...

    ORACLE中日期和时间函数汇总

    Oracle 中提供了多种日期和时间函数,以下是一些常用的函数: * SYSDATE:返回当前日期和时间。 * CURRENT_DATE:返回当前日期。 * CURRENT_TIMESTAMP:返回当前日期和时间。 * ADD_MONTHS:将月份添加到日期中。 ...

Global site tag (gtag.js) - Google Analytics