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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值