PHP+MySQL实现对一段时间内每天数据统计优化操作实例

在互联网项目中,对项目的数据分析必不可少。通常会统计某一段时间内每天数据总计变化趋势调整营销策略。下面来看以下案例。

案例

在电商平台中通常会有订单表,记录所有订单信息。现在我们需要统计某个月份每天订单数及销售金额数据从而绘制出如下统计图,进行数据分析。

PHP+MySQL实现对一段时间内每天数据统计优化操作实例

订单表数据结构如下:

order_id order_sn total_price enterdate
25396 A4E610E250C2D378D7EC94179E14617F 2306.00 2017-04-01 17:23:26
25397 EAD217C0533455EECDDE39659ABCDAE9 17.90 2017-04-01 22:15:18
25398 032E6941DAD44F29651B53C41F6B48A0 163.03 2017-04-02 07:24:36

此时查询某月各天下单数,总金额应当如何做呢?

一般方法

首先最容易想到的方法,先利用 php 函数 cal_days_in_month() 获取当月天数,然后构造一个当月所有天的数组,然后在循环中查询每天的总数,构造新数组。

代码如下:
 

$month = '04';
$year = '2017';
$max_day = cal_days_in_month(CAL_GREGORIAN, $month, $year);   //当月最后一天
//构造每天的数组
$days_arr = array();
for($i=1;$i<=$max_day;$i++){
  array_push($days_arr, $i);
}
$return = array();
//查询
foreach ($days_arr as $val){
  $min = $year.'-'.$month.'-'.$val.' 00:00:00';
  $max = $year.'-'.$month.'-'.$val.' 23:59:59';
  $sql = "select count(*) as total_num,sum(`total_price`) as amount 
from `orders` where `enterdate` >= {$min} and `enterdate` <= {$max}";
  $return[] = mysqli_query($sql);
}
return $return;

这个sql简单,但是每次需要进行30次查询请,严重拖慢响应时间。

优化

如何使用一个sql直接查询出各天的数量总计呢?
此时需要利用 mysql 的 date_format 函数,在子查询中先查出当月所有订单,并将 enterdate 用 date_format 函数转换为 天 ,然后按天 group by 分组统计。 代码如下:

$month = '04';
$year = '2017';
$max_day = cal_days_in_month(CAL_GREGORIAN, $month, $year);   //当月最后一天
$min = $year.'-'.$month.'-01 00:00:00';
$max = $year.'-'.$month.'-'.$max_day.' 23:59:59';
$sql = "select t.enterdate,count(*) as total_num,sum(t.total_price) as 
amount (select date_format(enterdate,'%e') as 
enterdate,total_price from orders where enterdate 
between {$min} and {$max}) t group by t.enterdate order by t.enterdate";
$return = mysqli_query($sql);

这样,将30次查询减少到1次,响应时间会大大提高。

本文来自投稿,不代表重蔚自留地立场,如若转载,请注明出处https://www.cwhello.com/6467.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
重蔚重蔚管理团队
上一篇 2018年4月25日 09:24
下一篇 2018年4月27日 00:00

相关推荐

  • PHP8.0中的日志库:Monolog

    随着互联网技术的不断发展和进步,越来越多的应用程序需要处理大量的数据和请求。为了确保应用程序能够正常运行和及时发现问题,记录日志以便排查问题变得尤为关键。日志是一种用于追踪和记录系统运行情况的信息记…

    2023年5月18日
    04
  • PHP8中的函数:str_starts_with()的多种具体应用。

    随着PHP8的发布,引入了许多新的函数和语言特性,其中一个非常有用的函数是str_starts_with()。它可以用来判断一个字符串是否以指定的前缀开始,这对于处理字符串非常有用。在本文中,我们将探讨str_starts_with()…

    2023年5月21日
    013
  • PHP 新手入门之变量的认识

    PHP 中的变量用一个美元符号后面跟变量名来表示。 变量名是区分大小写的。 变量名与 PHP 中其它的标签一样遵循相同的规则。 一个有效的变量名由字母或 者下划线开头,后面跟上任意数量的字母,数字,或者下划线 注…

    2018年12月11日
    0322
  • 在PHP中使用Memcache缓存技术提高优先队列的效率。

    随着社会的不断发展,人们对于计算机技术的要求也变得越来越高。在计算机中,队列是一种非常重要的数据结构,能够帮助我们高效地解决很多问题。然而,在实际的应用过程中,队列的效率却往往会受到一些因素的限制,…

    2023年5月21日
    02
  • 如何在PHP中使用Memcached缓存技术提高图片的加载速度

    随着互联网的发展,网站的访问量越来越大,为了提高网站的性能和用户体验,缓存技术成为了必不可少的一部分。其中,Memcached是一种高性能的分布式缓存系统,广泛应用于互联网领域,特别适用于缓存大量的读操作。本…

    2023年5月19日
    05
  • PHP调用网建科技短信接口实现短信发送。

    PHP调用网建科技短信接口实现短信发送随着移动互联网的快速发展,短信已经成为人们日常生活中必不可少的通信方式之一。企业也经常使用短信来进行业务的推广和服务的提醒。而如何方便地实现短信发送就成了一个关键性…

    2023年5月23日
    01
  • 基于PHP商城开发的卓越应用

    在当今的数字化时代,各行业对于电子商务平台的需求日益增长,跨越时间与空间的限制,让商业活动不再受制于地域和时间的限制,同时也满足了人们的闲暇、生活、工作和消费等多元需求,电子商务平台逐渐成为商务活动…

    2023年5月19日
    01
  • PHP中使用Redis实现分布式锁升级版。

    随着Web应用的发展,分布式架构已经成为了越来越多应用的标配。但是,在分布式架构中,如何保证多个应用同时访问同一资源的互斥性,保证数据的一致性,就成为了每个开发人员需要面对的问题。分布式锁就是一种保证互…

    2023年5月21日
    03

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息