广告
返回顶部
首页 > 资讯 > 数据库 >MySQL百分位数计算如何进行优化
  • 654
分享到

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

2024-04-02 19:04:59 654人浏览 八月长安
摘要

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

小编给大家分享一下Mysql百分位数计算如何进行优化,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

主要是采用存储过程,在中间计算结果中,增加了一个索引

原来的sql

  1. select t5.query_time,t5.ts,t2.v from (

  2.     select query_time,total,v, floor(1+(total-1)*v) rn

  3.     from (

  4.          select query_time,count(*) total from t group by query_time

  5.     ) t3, (select 0.71 v,1 seq uNIOn all select 0.81,2 union all select 0.91,3) t4

  6. )

  7. t2 inner join (

  8.     select

  9.     query_time,

  10.     case when @gid=query_time then @rn:=@rn+1 when @gid:=query_time then @rn:=1 end rn,

  11.     ts

  12.     from (

  13.         select * from t ,(select @gid:='',@rn:=0) vars order by query_time,ts

  14.     ) t1

  15. ) t5 on (t2.query_time=t5.query_time and t2.rn=t5.rn )



改进为存储过程

  1. drop procedure p;

  2. delimiter $$

  3. create procedure p()

  4. begin

  5.     drop table if exists tmp_result;

  6.     

  7.     create temporary table tmp_result(

  8.         query_time date,

  9.         rn int,

  10.         ts float,

  11.         key(query_time,rn)

  12.     ) engine =memory;

  13.     

  14.     insert ignore into tmp_result

  15.     select

  16.     query_time ,

  17.     case when @gid=query_time then @rn:=@rn+1 when @gid:=query_time then @rn:=1 end rn,

  18.     ts

  19.     from (

  20.         select * from t ,(select @gid:='',@rn:=0) vars order by query_time,ts

  21.     ) t1 ;


  22.     select t5.query_time,t5.ts,t2.v from (

  23.         select query_time,total,v, floor(1+(total-1)*v) rn

  24.         from (

  25.              select query_time,count(*) total from t group by query_time

  26.         ) t3, (select 0.71 v,1 seq union all select 0.81,2 union all select 0.91,3) t4

  27.     )

  28.     t2 inner join tmp_result t5 on (t2.query_time=t5.query_time and t2.rn=t5.rn );

  29. end $$


  30. delimiter ;


  31. call p

使用存储过程 一般 11秒 左右

以上是“mysql百分位数计算如何进行优化”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网数据库频道!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL百分位数计算如何进行优化

本文链接: https://www.lsjlt.com/news/62557.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL百分位数计算如何进行优化
    小编给大家分享一下MySQL百分位数计算如何进行优化,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!主要是采用存储过程,在中间计算...
    99+
    2022-10-18
  • MySQL百分位数如何计算
    这篇文章主要为大家展示了“MySQL百分位数如何计算”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“MySQL百分位数如何计算”这篇文章吧。select...
    99+
    2022-10-18
  • MySQL如何实现百分位数计算
    这篇文章主要介绍了MySQL如何实现百分位数计算,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。创建试验数据,5天每天一百万随机数据,总共50...
    99+
    2022-10-18
  • MySQL如何进行优化
    这篇文章主要讲解了“MySQL如何进行优化”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL如何进行优化”吧! 案例背景案例分析MySQL ...
    99+
    2022-10-18
  • 如何在Python中进行并行计算和分布式计算
    如何在Python中进行并行计算和分布式计算随着计算机技术的不断发展和硬件性能的提升,利用多核处理器进行并行计算和分布式计算已成为提高程序性能的重要手段之一。而Python作为一门简洁易用且功能强大的编程语言,也提供了丰富的库和工具来支持并...
    99+
    2023-10-22
    并行计算 (Parallel computing) Python (Python) 分布式计算 (Distributed
  • ntfs硬盘如何进行整数的分区计算
    本篇文章给大家分享的是有关ntfs硬盘如何进行整数的分区计算,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。到底整数分区会得到整数的容量结果分区计算方法:较早时间的计算方法为:M...
    99+
    2023-06-14
  • 如何实现MySQL底层优化:执行计划分析和优化技巧
    实现MySQL底层优化:执行计划分析和优化技巧引言在数据库应用程序的开发和运维中,针对MySQL数据库进行底层优化是非常重要的。MySQL执行计划分析和优化技巧可以帮助开发人员和运维人员提升数据库的性能和稳定性,本文将介绍如何实现MySQL...
    99+
    2023-11-08
    优化技巧 执行计划 底层优化 MySQL优化关键词:
  • PHP中如何进行服务计算和分布式计算?
    PHP是一种功能强大的服务器端脚本语言,广泛用于Web开发。随着互联网的发展,越来越多的企业需要处理大量的数据和请求,一台服务器已经无法满足需求。为了提高系统的可伸缩性、灵活性和可靠性,进行服务计算和分布式计算已变得越来越重要。服务计算(S...
    99+
    2023-05-20
    PHP 分布式计算 服务计算
  • MySQL索引如何进行优化
    这篇文章主要介绍了MySQL索引如何进行优化,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。  创建 test 测试表  CREATE TAB...
    99+
    2022-10-19
  • 如何进行limit分页优化
    这篇文章给大家介绍如何进行limit分页优化,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 看一个案例 点击(此处)折叠或打开 mysql> ...
    99+
    2022-10-19
  • PHP中如何进行大规模计算和分布式计算?
    随着互联网的不断发展,Web应用程序的规模越来越大,需要处理更多的数据和更多的请求。为了满足这些需求,计算大规模数据和分布式计算成为了一个必不可少的需求。而PHP作为一门高效、易用、灵活的语言,也在不断发展和改进自身的运行方式,逐渐成为计算...
    99+
    2023-05-22
    分布式计算 PHP计算 大规模计算
  • 如何使用C++进行算法优化?
    如何使用C++进行算法优化概述:在计算机科学领域,算法优化是提高算法效率和性能的关键过程。使用C++编写算法的一个重要方面是了解如何优化算法来减少时间和空间复杂度。本文将介绍一些可用的技术和策略,帮助开发者在C++中实现高效的算法。1.选择...
    99+
    2023-11-04
    编程 使用 C++ 算法优化
  • 如何进行Mysql SSD下的MySQL IO 优化
    这篇文章给大家介绍如何进行Mysql SSD下的MySQL IO 优化,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 背景 在阅读这篇文章之前,读者需要注意的是,为了维护隐...
    99+
    2022-10-18
  • 如何进行SQL优化中的limit分页优化
    如何进行SQL优化中的limit分页优化,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。示例 表aaaaa中共有2375690数据。优化前的S...
    99+
    2022-10-19
  • 计算机网络中网站如何进行代码层的优化
    这篇文章将为大家详细讲解有关计算机网络中网站如何进行代码层的优化,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、如何在head层进行优化目前title在SEO中的占比已经不是非常重要了,只要选择合适的行...
    99+
    2023-06-10
  • MySQL数据库设计时如何优化
    小编给大家分享一下MySQL数据库设计时如何优化,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!  1、命名的技巧与规范  无论什...
    99+
    2022-10-19
  • 如何使用 numpy 进行数学计算?
    Numpy 是一个 Python 库,用于快速处理和计算大量数据。它提供了高效的多维数组对象,以及用于处理这些数组的各种函数。在数据科学和机器学习等领域,numpy 是必不可少的工具之一。在本文中,我们将探讨如何使用 numpy 进行数学...
    99+
    2023-10-01
    文件 numpy javascript
  • 如何实现MySQL底层优化:数据统计和分析的应用与优化
    如何实现MySQL底层优化:数据统计和分析的应用与优化随着互联网的迅猛发展,数据对于企业的重要性越来越突出。而MySQL作为一种常用的开源关系型数据库管理系统,其底层优化对于数据统计和分析应用的性能至关重要。本文将重点介绍如何实现MySQL...
    99+
    2023-11-08
    数据分析 优化 数据统计 MySQL底层优化关键词:
  • 如何进行MySQL中的order by 优化
    这篇文章将为大家详细讲解有关如何进行MySQL中的order by 优化,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。 一 前言...
    99+
    2022-10-19
  • 如何进行MySQL优化WHERE子句
    今天就跟大家聊聊有关如何进行MySQL优化WHERE子句,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 MyS...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作