Oracle 分析函数之row_number(), over

1:Oracle 分析函数row_number()用mysql实现

SELECT module, machine, time, @row:=@row+1 rownum

FROM total_freq_ctrl, (select @row:=0) b 

order by module,machine,time desc

在这里插入图片描述

2:Oracle 分析函数over (partition by job order by id desc ) 的 Mysql实现

oracle 开窗函数,对结果集已sex分组并已id排序

select * from (
select name,if(@temp=job,@rank:=@rank+1,@rank:=1) as rank,  
@temp:=job from (select * from emp) a, (select  @temp:= null ,@rank:=0) b
) c where rank=1  order by id desc

if 解释:会对结果逐个判断,满足就加一,不满足就新起一个

另一种高效写法

select * from (
SELECT name,
       case when @mid = jobthen @row:=@row+1 else @row:=1 end rownum,
       @mid:=job
FROM heyf_t10
order by job,salary desc) tt where tt.rownum=1;

类似于下图效果

在这里插入图片描述

附另一种实现方式 :https://blog.csdn.net/Howie_zhw/article/details/51706282

3:Oracle计算百分比并保留两位小数-mysql实现

oracle

select round(6/3335,4)    from  dual;
select round(6/3335,4)*100.00||'%'    from  dual;
select to_char(round(6/3335,4)*100.00,'fm90.09')||'%'    from  dual;

mysql

select concat(format(round(6/3335,4)*100.00,4),2),'%' )   from  dual;

4:mysql类型转换

convert(value,type) 
case( 字段  int)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值