--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)/365 年 from 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