由于有一段代码要用到while 循环代码,一旦数据量大了就会失败,求解决方案啊 ....
while($rows = $query->fetch_array()){
if($rows['mingxi_1']=='1'){
$ds = Ssc_Ds($rs['ball_1']);
$dx = Ssc_Dx($rs['ball_1']);
if($rows['mingxi_2']==$rs['ball_1'] || $rows['mingxi_2']==$ds || $rows['mingxi_2']==$dx){
$msql="update c_bet set js=1 where id='".$rows['id']."'";
$mysqli->query($msql) or die ("修改订单状态失败!!!".$rows['id']);
//给会员账户增加奖金
$msql="update k_user set money=money+".$rows['win']." where uid=".$rows['uid']."";
$mysqli->query($msql) or die ("修改失败!!!".$rows['id']);
}else{
//注单未中奖,修改注单内容
$msql="update c_bet set win=0,js=1 where id=".$rows['id']."";
$mysqli->query($msql) or die ("修改失败!!!".$rows['id']);
}
}
1.能不能上完整版的代码?SQL也不舍不得拿出来?
2.目测是SQL的结果集太多,内存可能溢出,而且操作可能耗时
3.解决方案:用redis队列 或者 MySQL队列解决