dskm94301 2019-04-12 05:06
浏览 159
已采纳

使用php将excel数据导入数据库表

problem is in my excel 369 rows are there. when I echo/print that data it showing correct but when I am inserting same data in DB table in inserted only 18 - 30 records.

if (isset($_POST['Submit'])) {
    $file = $_FILES['csv_file']['tmp_name'];
    $handle = fopen($file, "r");
    if ($file == NULL) {
    error(_('Please select a file to import'));
    redirect(page_link_to('excel_data_upload'));
    }else {
        $conn = connect();
        while(($filesop = fgetcsv($handle, 1000, ",")) !== false)
        {
            $num3 = $filesop[3];
            $num8 = $filesop[8];
            $num9 = $filesop[9];
            $num20 = $filesop[20];
            if($num3!='ExpiryDate' &&$num8!='VCNO' &&$num20!='TotalB2CAmount' && $num9 !='STBNO'){

                $insertAgent =  mysqli_query($conn, "INSERT INTO `upload_billing_data` 
                (`vc_number`,`stb_number`,`operator_id`,`expiry_date`,`monthly_bill_amount`) 
                VALUES ('$num8','$num9',140,'$num3','$num20')");

                if($insertAgent)
                {
                    echo 'succss';
                }else{
                    echo 'error';
                }

            }  
        }
        close($conn);

    }
}

I am fetching from the excel data. I want to insert all records

  • 写回答

2条回答 默认 最新

  • doushi8187 2019-04-12 08:51
    关注

    Change the code as below and you might get to save all data using one query to the database:

    $query_insert = array();
    
    while(($filesop = fgetcsv($handle, 1000, ",")) !== false) {
       $num3 = filterString($filesop[3]);
       $num8 = filterString($filesop[8]);
       $num9 = filterString($filesop[9]);
       $num20 = filterString($filesop[20]);
    
       if ($num3!='ExpiryDate' &&$num8!='VCNO' &&$num20!='TotalB2CAmount' && $num9 !='STBNO') {
          $query_insert[] = "('{$num8}', '{$num9}', 140, '{$num3}', '{$num20}')";
       }  
    }
    
    // If no row matched your if, then there will be no row to add to the database
    if (count($query_insert)>0) {
       $conn = connect();
    
       $query_insert_string = implode(', ', $query_insert);
    
       $query = "INSERT INTO `upload_billing_data` (`vc_number`, `stb_number`, `operator_id`, `expiry_date`, `monthly_bill_amount`) VALUES {$query_insert_string};";
       $insertAgent = mysqli_query($query);
    
       // The rest of you code 
       ...
    
       close($conn);
    }
    
    
    
    // This function makes sure that you string doesn't contain characters that might damage the query
    function filterString($string) {
       $string = str_replace(array("\'", '"'), array('', ''), $string);
       $string = filter_var($string, FILTER_SANITIZE_STRING);
       return $string;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥30 51单片机C语言数码管驱动单片机为AT89C52
  • ¥100 只改动本课件的 cal_portfolio_weight_series(decision_date), 跑完本课件。设计一个信息比率尽量高的策略。
  • ¥20 如何在visual studio 2022中添加ImageMagick库
  • ¥50 如何实现uniapp编译的微信小程序做可回溯视频
  • ¥15 求Houdini使用行家,付费。价格面议。
  • ¥15 前端高拍仪调用问题报错
  • ¥15 想用octave解决这个数学问题
  • ¥15 Centos新建的临时ip无法上网,如何解决?
  • ¥15 海康威视如何实现客户端软件对设备语音请求的处理。
  • ¥15 支付宝h5参数如何实现跳转