foreach求和的效率和连接mysql的sum求和的效率

本文对比了两种项目进度更新方法:一种使用PHP foreach循环求和,另一种利用MySQL的SUM函数进行求和。实验证明,在少量数据下,PHP循环更快;但随着数据增加,MySQL SUM性能更优。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

范例:
    /**
     * 更新项目进度1 使用foreach循环求和
     */
    public function save_pro_finish_proportion1($pid){
    $list = $this->model_model->where('pid',$pid)->field('id,finish_proportion,weight')->select();
    $sum_weight = 0;
    $sum_finish_proportion = 0;
    foreach ($list as $k=>$v){
         $sum_weight += $v['weight'];
    }
    foreach ($list as $k=>$v){
         $finish_proportion = ($v['finish_proportion']/100)*$v['weight']/$sum_weight;
         $sum_finish_proportion += $finish_proportion;
    }
    echo $sum_finish_proportion;die;
    }
    /**
     * 更新项目进度2 使用mysql的sum求和
     */
    public function save_pro_finish_proportion2($pid){
    $list = $this->model_model->where('pid',$pid)->field('id,finish_proportion,weight')->select();
    $sum_weight = $this->model_model->where('pid',$pid)->sum('weight');
    $sum_finish_proportion = 0;
    foreach ($list as $k=>$v){
         $finish_proportion = ($v['finish_proportion']/100)*$v['weight']/$sum_weight;
         $sum_finish_proportion += $finish_proportion;
    }
    echo $sum_finish_proportion;die;
    }
实验结果:在10条记录的情况下,使用foreach循环求和  要比  使用mysql的sum求和 平均求和并得出结果的速度  要快5ms左右;
        60条数据时,平均值不相上下;
        当数据有400条时候   使用mysql的sum求和  明显要比  使用foreach循环求和 平均值和每一组数据  都要快10ms;
结论 : 数据量小,使用mysql连接开销要比php后台语言循环 开销大 ,一旦数据量变大 应当使用mysql求和更好;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值