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

相关推荐

  • 微信小程序中PHP实现事件提醒和闹钟功能。

    随着智能手机的普及,人们的生活变得越来越方便。人们可以用手机上的应用完成各种任务,如购物、旅游、学习等等。而随着微信小程序的出现,人们可以在微信上更加方便地完成各种任务。微信小程序可以直接在微信中使…

    2023年6月3日
    06
  • Cookie基本使用(增删改查)

    创建cookie(增加) setcookie();setcookie有7个参数: 参数1:保存的cookie变量名称 参数2:变量对应的值 参数3:cookie文件的有效期 读取cookie的数据 参数4:有效路径 默认情况只允许访问当前目录、当前目录子目…

    2018年9月13日 PHP自学教程
    0263
  • PHP数据库操作:memcache用法分析(附代码)

    memcache简介 Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等。简单的说就是将数据调用到…

    2018年3月19日
    0180
  • 微信小程序中PHP实现单选、多选和复选框的实现方法。

    随着微信小程序的日益普及,越来越多的开发者开始关注微信小程序的开发。微信小程序作为一种全新的开发模式,在实现不同功能上需要不同的技术方案。其中,实现单选、多选和复选框是微信小程序开发者经常会面临的一…

    2023年6月3日
    02
  • PHP操作MySQL的流程

    1.链接数据库 2.选择数据库并设置编码 3.准备SQL语句 4.发生SQL语句到MySQL服务器 5.接收返回的结果集资源 6.解析结果集资源 7.关闭链接资源 流程图:

    2018年3月23日
    0290
  • 聊聊html怎么嵌套php。

    要在HTML中嵌入PHP代码,你需要确保你的服务器支持PHP,并且文件的扩展名是.php,在HTML文件中嵌入PHP代码非常简单,只需在HTML标签之间使用<?php和?>标签包围PHP代码即可,以下是一个简单的示例: (图片来…

    2024年6月21日
    00
  • 浅谈CGI、FastCGI、PHP-CGI、PHP-FPM!

    CGI与FastCGI的理解CGI与FastCGI都是一种通讯协议,是web Sever(Apache/nginx/iis)与其他程序(此程序通常叫做CGI程序,如PHP脚本解析器)之间通讯的桥梁FastCGI是CGI的改良进化版,FastCGI相比CGI更安全、性能更…

    2022年6月12日
    0138
  • GOTO语句

    goto语句就是在页面中的不同位置进行跳转. 语法:  Goto 表示名;                        可以写代码;              表示名: 案例:

    2018年4月1日
    0210

联系我们

QQ:951076433

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