Oracle命令(四)--日期函数

 

--sysdate:输出默认时间 日-月-年

 

select to_char(sysdate, yyyy-mm-dd hh24:mi:ss) from dual; //按照指定格式输出时间信息

 

--日期的运算

计算:入职时间,天,周,月,年

select ename,(sysdate-hiredate) 天, (sysdate-hiredate)/7 周,(sysdate-hiredate)/30 月,(sysdate-hiredate)/365from emp

 

日期的四舍五入

select round (sysdate, MONTH) from dual;
select round (sysdate, YEAR) from dual;
select TRUNC (sysdate, MONTH) from dual;
select TRUNC (sysdate, YEAR) from dual;

 


SQL显示转化

 

字符串->数字

 

select 111 + 222 from dual;    //111字符串转成了数字 111

 

数字->字符串

select 111 || 222 from dual;    //将 222数字转化成了字符串 222

 

字符串->日期

select * from emp where hiredate > to_date(1981-01-01, yyyy-mm-dd);

 

日期->字符串

--查询 比 19810101 入职晚点的员工

 

select * from emp where to_char(HIREDATE, yyyy-mm-dd) > 19810101 

to_char函数对数字的转化

 

--查询员工的薪水:两位小数 本地货币代码 千位符

 

select ename,to_char(sal, L9,999,99) from emp

 

to_number函数
将 某一个格式的 字符串转化成数字

通用函数


nvl2(a,b,c); 当 a = null 的时候, 返回 b, 否则就返回 c。 ==> return a == NULL ? b : c;
nullif(a,b); //当 a = b 时,返回null,否则返回 a
coalsece(a,b,c...); //从左到右返回第一个不为空的

条件表达式(if-then-else):做报表

select ename, sal 涨钱工资, sal 涨后工资 from emp;
select ename,job, sal 涨前工资,
(
CASE job WHEN PRESIDENT THEN sal + 1000
WHEN MANAGER    THEN sal + 800
ELSE sal+500
END
)
涨后工资
from emp

 

Oracle命令(四)--日期函数

上一篇:Spring JdbcTemplate小结


下一篇:数据库设计中的一些技巧