范例:
/**
* 更新项目进度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求和更好;