php pcntl 单个进程查询数据不对

果酱很好吃 2014-07-07 05:37:05
$num = 10;
$pids = array();

$limit=ceil(10/$num);

for($i = 1; $i <= $num; $i++) {
$pids[$i] = pcntl_fork();
if(!$pids[$i]) {
$start=($i-1)*$limit;
$pushinfo=array();
$pushk=0;

$sql="SELECT id,phoneToken FROM pre_test ORDER BY id LIMIT $start,$limit";
$res=DB::query($sql);
while($row=mysql_fetch_assoc($res)){
$pushinfo[]=$row;
$pushk++;
}

file_put_contents('/home/log.txt',var_export($pushinfo,true).'-'.$sql.'-'.$i.PHP_EOL,FILE_APPEND);
exit();
}
}

for($i = 1; $i <= $num; $i++) {
pcntl_waitpid($pids[$i], $status, WUNTRACED);
}

输出file_put_contents的结果(只取两条)
正确:
array (
0 =>
array (
'id' => '1',
'phoneToken' => 'f23b58df4ec2995eed4e9deb15a246381a664ad160736052822faf91bb161bba',
),
)-SELECT id,phoneToken FROM pre_test ORDER BY id LIMIT 0,1-1
错误:
array (
0 =>
array (
'id' => '6',
'phoneToken' => '19cfa2836408fe164cadc9545e658a206b5031bdf3497b386cc626ab52',
),
)-SELECT id,phoneToken FROM pre_test ORDER BY id LIMIT 6,1-7
错误描述:
我的数据库里只有十条数据,且id是1到10,也就是说,我开十个子进程,每个进程取出的数据id应该和$i相同,但现在不是。并且,我将错误数据打印出的sql语句执行后,返回的结果是id为7 的那条数据。
最重要的是:返回的十条数据中,有可能有两条是相同的,但却是不同的进程返回的,十条sql语句的limit都不相同。

请问:
是不是$pushinfo这个变量,在十个子进程中公用了?
如何解决子进程取出数据不对应的问题?
...全文
153 回复 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

21,893

社区成员

发帖
与我相关
我的任务
社区描述
从PHP安装配置,PHP入门,PHP基础到PHP应用
社区管理员
  • 基础编程社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧