• 技术文章 >后端开发 >PHP问题

    php 怎么查询一段时间内的数据库

    藏色散人藏色散人2022-11-04 09:48:56原创179

    php查询一段时间内的数据库的方法:1、利用mysql的“date_format”函数,在子查询中先查出当月所有订单;2、将enterdate用“date_format”函数转换为天;3、按天“group by”分组统计即可。

    php入门到就业线上直播课:进入学习

    本教程操作环境:windows7系统、PHP8.1版、Dell G3电脑。

    php 怎么查询一段时间内的数据库?

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

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

    案例

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

    订单表数据结构如下:

    order_idorder_sntotal_priceenterdate
    25396A4E610E250C2D378D7EC94179E14617F2306.002017-04-01 17:23:26
    25397EAD217C0533455EECDDE39659ABCDAE917.902017-04-01 22:15:18
    25398032E6941DAD44F29651B53C41F6B48A0163.032017-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次,响应时间会大大提高。

    注意:

    1.由于需查询当月所有数据,在数据量过大时,不宜采取本方法。

    2.为避免当天没有数据而造成的数据缺失,在查询后,理应根据需求对数据进行处理。

    推荐学习:《PHP视频教程

    以上就是php 怎么查询一段时间内的数据库的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    自己动手写 PHP MVC 框架:点击学习

    快速了解MVC架构、了解框架底层运行原理

    专题推荐:php 数据库
    上一篇:wamp无法解析php文件怎么办 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• 一文带你快速了解MySQL中的慢查询• PHP怎么查询手机号码归属地• php mysql如何查询个数• php怎么实现星座查询• MySQL基础之多表查询案例分享
    1/1

    PHP中文网