php优化上百次foreach,php – 优化数千个项目的foreach
我在一組25,000個(gè)結(jié)果中運(yùn)行下面的代碼.我需要優(yōu)化它,因?yàn)槲疫_(dá)到了內(nèi)存限制.
$oldproducts = Oldproduct::model()->findAll(); /*(here i have 25,000 results)*/
foreach($oldproducts as $oldproduct) :
$criteria = new CDbCriteria;
$criteria->compare('`someid`', $oldproduct->someid);
$finds = Newproduct::model()->findAll($criteria);
if (empty($finds)) {
$new = new Newproduct;
$new->someid = $oldproduct->someid;
$new->save();
} else {
foreach($finds as $find) :
if ($find->price != $oldproduct->price) {
$find->attributes=array('price' => $oldproduct->price);
$find->save();
}
endforeach;
}
endforeach;
代碼通過someid比較兩個(gè)表的行.如果它發(fā)現(xiàn)巧合,它會(huì)更新價(jià)格列,如果沒有創(chuàng)建新記錄.
創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)總結(jié)
以上是生活随笔為你收集整理的php优化上百次foreach,php – 优化数千个项目的foreach的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: currenthashmap如何实现线程
- 下一篇: desktop docker 无法卸载_