首页  >  问答  >  正文

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

如题。

            while(! feof($file)){
                $data= fgets($file);//fgets()函数从文件指针中读取一行
                $res = $this->Model->function($data);//插入数据的方法
            }
            //比如这种的怎么判断每一行都插入成功
阿神阿神2668 天前867

全部回复(6)我来回复

  • 学习ing

    学习ing2017-06-30 09:55:58

    // 定义变量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即为失败条数

    }

    回复
    0
  • 怪我咯

    怪我咯2017-06-30 09:55:58

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

    回复
    0
  • 巴扎黑

    巴扎黑2017-06-30 09:55:58

    雷雷

    回复
    0
  • 巴扎黑

    巴扎黑2017-06-30 09:55:58

    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)
        }
    }

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

    回复
    0
  • 高洛峰

    高洛峰2017-06-30 09:55:58

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

    回复
    0
  • 黄舟

    黄舟2017-06-30 09:55:58

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

    回复
    0
  • 取消回复