当前位置: 代码迷 >> SQL >> Sql 漫笔
  详细解决方案

Sql 漫笔

热度:273   发布时间:2016-05-05 11:08:40.0
Sql 随笔

新进入一家公司,保险行业,系统比较老,所以java代码技术没什么好学的,但是写算法,写存储过程,sql语句比较多,

以此篇文章记录自己的sql历程,完全是流水账式记录,大家谨慎阅读!

?1,查询两个日期相差多少个月,就用months_between,注意是前边时间减去后边的,如果前边小,会减出负数

select months_between(to_date('2006-05-17','YYYY-MM-DD'),to_date('2006-01-01','YYYY-MM-DD')) from dual;

?如果不想要后边的小数部分,就用floor

select floor(months_between(to_date('2006-05-17','YYYY-MM-DD'),to_date('2006-01-01','YYYY-MM-DD'))) from dual;

?

如果说你要查询某个人入职第几年的话,可以再除以12个月,像保险行业,每年都有不同的业务指标,可能会用到

select floor(months_between(sysdate,to_date('2014-07-23','yyyy-mm-dd'))/12)+1 from dual; 

?

执行结果为1.

如果你想计算某个数,返回百分数,并且保留几位小数

 select  (ROUND(7/9,4)*100)||'%' from dual;  select   trunc(7/9,4)*100||'%' from dual ;

执行结果是: 77.78% 和 77.77%
  相关解决方案