foreach求和的效率和连接mysql的sum求和的效率
范例: /** * 更新项目进度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求和更好;
阅读更多
声明:该文观点仅代表作者本人,入门客AI创业平台信息发布平台仅提供信息存储空间服务,如有疑问请联系rumenke@qq.com。
- 上一篇: 字数限制截取
- 下一篇:没有了