1)trunc(number,num_digits)
Number是需要截尾取整的数字,也可以是日期
Num_digits用于指定整精度的数字(默认为0)。
trunc()函数截取时不进行四舍五入
--为123.456,123.546取整
select trunc(123.456),trunc(123.546) from dual;
--保留123.456小数点后俩位小数和小数点前俩位小数
select trunc(123.456,2),trunc(123.456,-2) from dual;
trunc()操作日期:
--使用trunc函数得到当天的凌晨,当月的第一天,今年的第一个月
select to_char(trunc(sysdate),'yyyy-mm-dd hh24-mi-ss'),
to_char(trunc(sysdate,'mm'),'yyyy-mm-dd hh24-mi-ss'),
to_char(trunc(sysdate,'yyyy'),'yyyy-mm-dd hh24-mi-ss')
from dual;
2)decode(条件,值1,返回值1,值2,返回值2,....,值n,返回值n,缺省值)
decode是oracle独有的函数,mysql还没有实现该功能
该函数的含义如下:
if 条件=值1 then
return 值1
else 条件=值2 then
return 值2
......
else 条件=值n then
return 值n
else
return 缺省值
end if
--实验decode函数
select sign(1-3),decode(sign(1-3),1,'x',-1,'y','z') from dual;
select sign(1-1),decode(sign(1-1),1,'x',-1,'y','z') from dual;
select sign(1+1),decode(sign(1+1),1,'x',-1,'y','z') from dual;