分享更有价值
被信任是一种快乐

MySQL百分位数计算如何进行优化

文章页正文上

小编给大家分享一下MySQL百分位数计算如何进行优化,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!主要是采用存储过程,在中间计算结果中,增加了一个索引

原来的SQL

select t5.query_time,t5.ts,t2.v from (
select query_time,total,v, floor(1+(total-1)*v) rn
from (
select query_time,count(*) total from t group by query_time
免费主机域名 ) t3, (select 0.71 v,1 seq union all select 0.81,2 union all select 0.91,3) t4
)
t2 inner join (
select
query_time,
case when @gid=query_time then @rn:=@rn+1 when @gid:=query_time then @rn:=1 end rn,
ts
from (
select * from t ,(select @gid:=”,@rn:=0) vars order by query_time,ts
) t1
) t5 on (t2.query_time=t5.query_time and t2.rn=t5.rn )

改进为存储过程

drop procedure p;
delimiter $$
create procedure p()
begin
drop table if exists tmp_result;

create temporary table tmp_result(
query_time date,
rn int,
ts float,
key(query_time,rn)
) engine =memory;

insert ignore into tmp_result
select
query_time ,
case when @gid=query_time then @rn:=@rn+1 when @gid:=query_time then @rn:=1 end rn免费主机域名,
ts
from (
select * from t ,(select @gid:=”,@rn:=0) vars order by query_time,ts
) t1 ;

select t5.query_time,t5.ts,t2.v from (
select query_time,total,v, floor(1+(total-1)*v) rn
from (
select query_time,count(*) total from t group by query_time
) t3, (select 0.71 v,1 seq union all select 0.81,2 union all select 0.91,3) t4
)
t2 inner join tmp_result t5 on (t2.query_time=t5.query_time and t2.rn=t5.rn );
end $$

delimiter ;

call p 使用存储过程 一般 11秒 左右
以上是“MySQL百分位数计算如何进行优化”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注云技术行业资讯频道!

相关推荐: PHP的SQL注入完整过程

这篇文章主要介绍“PHP的SQL注入完整过程”,在日常操作中,相信很多人在PHP的SQL注入完整过程问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PHP的SQL注入完整过程”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!  S…

文章页内容下
赞(0) 打赏
版权声明:本站采用知识共享、学习交流,不允许用于商业用途;文章由发布者自行承担一切责任,与本站无关。
文章页正文下
文章页评论上

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册