PHP循环向MySQL数据库插入数据,怎么判断是否每条都插入成功?

如题。

            while(! feof($file)){
                $data= fgets($file);//fgets()函数从文件指针中读取一行
                $res = $this->Model->function($data);//插入数据的方法
            }
            //比如这种的怎么判断每一行都插入成功
阅读 5.9k
6 个回答

// 定义变量num
$num = 0;
while (! feof($file)) {

$data= fgets($file);//fgets()函数从文件指针中读取一行
$res = $this->Procesratio->promction($data);

// 直接在这里判断
if (!$res) {
    $num += 1;
}

}

// 这里判断一下num的值
if ($num == 0) {

// 全部成功

} else {

// $num即为失败条数

}

开启事务transaction,只要有一条出错就rollback,并且抛出异常

if($res == true){
   echo "success";
}else{
    echo "fault";
}
while(! feof($file)){
    $data= fgets($file);//fgets()函数从文件指针中读取一行
    $res = $this->Model->function($data);//插入数据的方法
    if($res){
        echo "success!";
    }else{
        echo "error!。。。try again....";
        $this->Model->function($data)
    }
}

插入成功后有会返回数据,根据返回做判断就好了!!

这种大数据量的插入方式,如果线上业务没那么繁忙的话,可以考虑分批插入,批量插入之后,返回结果就是受影响的行数。返回结果比较好查找而且效率会比这个高一些。或者是事务,简单暴力。

建议用事物吧,这样至少可以保证数据的一致性吧。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题