field" />
牛骨文教育服务平台(让学习变的简单)
博文笔记

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

创建时间:2018-06-27 投稿人: 浏览次数:285
范例:    /**     * 更新项目进度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求和更好; 阅读更多
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。