Oracle / PLSQL函数 - NUMTODSINTERVAL和NUMTOYMINTERVAL
2017-01-10 11:26
375 查看
最近在学习数据库方面的知识,做个标记。
这里有英文解释,建议多看看英文文档: https://www.techonthenet.com/oracle/functions/[/code]
下面开始记录一下,自己在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;
相关文章推荐
- Oracle计算时间函数(numtodsinterval、numtoyminterval)
- Oracle计算时间函数(numtodsinterval、numtoyminterval)
- Oracle计算时间函数(numtodsinterval、numtoyminterval)
- oracle numtodsinterval and numtoyminterval 使用法则
- Oracle计算时间函数(对时间的加减numtodsinterval、numtoyminterval) (转)
- Oracle计算时间函数(对时间的加减numtodsinterval、numtoyminterval)
- Oracle计算时间函数(numtodsinterval、numtoyminterval)
- Oracle-numtodsinterval&numtoyminterval
- oracle使用numtoyminterval来添加准确的月或者年
- Oracle时间计算函数numtodsinterval
- Oracle 时间函数NumToYMInterval()
- Oracle时间函数numtoyminterval()
- numtodsinterval and interval for oracle
- Oracle时间函数numtoyminterval()
- sign、decode、numtodsinterval、numtoyminterval、substr
- interval分区,按天分区,需要用到函数numtodsinterval
- ADD_MONTHS和numtodsinterval浅析
- ORA-01578:Oracle data block corrupted(file # num,block # num)
- Oracle 自动拓展分区的实现(11g后使用interval分区)
- 全面学习ORACLE Scheduler特性(6)设置Repeat Interval参数