Oracle / PLSQL函数 - NUMTODSINTERVAL和NUMTOYMINTERVAL

最近在学习数据库方面的知识,做个标记。
这里有英文解释,建议多看看英文文档:

https://www.techonthenet.com/oracle/functions/

下面开始记录一下,自己在Oracle或者PLSQL常用的几个函数,

1、NUMTODSINTERVAL( number, expression )
参数说明:
number:数字类型的值
expression:单位,这里的单位是固定的,有DAY,HOUR,MINUTE,SECOND
举例说明:
-- 当前日期加25天
select sysdate, sysdate + numtodsinterval(25, 'day') as res from dual;

-- 当前日期加2小时,这里转换了下时间格式,更容易看出来,下图所示
select to_char(sysdate, 'yyyy-MM-dd hh24:mi:ss'), to_char(sysdate + numtodsinterval(2, 'hour'), 'yyyy-MM-dd hh24:mi:ss') as res from dual;

-- 当前日期加分钟,秒,可以依葫芦画瓢,尝试写一下

显示效果如下图所示:

 

与此同时,和他相同的函数是下面的函数

2、NUMTOYMINTERVAL( number, expression )
参数说明:
number:数字类型的值
expression:单位,这里的单位是固定的,有MONTH,YEAR
举例说明:
-- 当前日期加2月
select sysdate, sysdate + numtoyminterval(2, 'month') as res from dual;

-- 当前日期加2年
select sysdate, sysdate + numtoyminterval(2, 'year') as res from dual;

 显示效果如下图所示:

 

3、DECODE( expression , search , result [, search , result]... [, default] )
参数说明: 
expression : 表中的某一列
search : 替换前的值,表中的枚举类型值(数据)
result : 替换后的值,展示数
举例说明:
-- 下表中,我有一个字段,字段的值有0,1
SELECT STATE FROM tableName;

-- 那么,我现在不想展示0,1,而是想展示“是”,“否”字段(0:否,1:是),可以使用这个函数DECODE
SELECT DECODE(STATE, 0, '否', 1, '是') AS STATE FROM tableName;

 

 

-- 如果有多个对应值,那么就在后面累积增加,例如
SELECT DECODE(CLASS, 1, '一年级', 2, '二年级', 3, '三年级', 4, '四年级', ... , n, 'n年级') AS CLASS FROM tableName;

 

转载于:https://www.cnblogs.com/yuchuan/p/oracle_NUMTODSINTERVAL.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值