Home  >  Article  >  Backend Development  >  How to implement batch upload of data to database in php

How to implement batch upload of data to database in php

墨辰丷
墨辰丷Original
2018-05-21 14:22:153828browse

The following editor will bring you a case of batch uploading data to the database (.csv format) in PHP. The editor thinks it’s pretty good, so I’ll share it with you now and give it as a reference. Let’s follow the editor and take a look.

Friendly reminder: The document for uploading data needs to be converted into a .csv format document

Front-end code:

<form name="importForm" action="import.php" method="POST" enctype="multipart/form-data"> 
<input type="hidden" value="import_goods" name="file"> 
  <table cellpadding="2" cellspacing="1" class="tb"> 
    <tbody> 
    <tr> 
      <td width="200">选择批量上传文档:</td> 
      <td><input type="file" name="upfilename" id="upfilename" value=""></td> 
    </tr> 
    <tr> 
      <td colspan="2"> 
        <input type="submit" name="submit" value="提交" class="btn"> 
      </td> 
    </tr> 
    </tbody> 
  </table> 
</form>

Back-end code: import.php file(Only the main code is pasted here, the specific implementation method requires Complete it yourself)

if(isset($_POST[&#39;submit&#39;])){ 
      stripos(PHP_OS, "WIN") !== false ? setlocale(LC_ALL, &#39;&#39;) : setlocale(LC_ALL,&#39;zh_CN.GBK&#39;); 
       
      $fext = substr($_FILES[&#39;upfilename&#39;][&#39;name&#39;], strrpos($_FILES[&#39;upfilename&#39;][&#39;name&#39;], &#39;.&#39;) + 1); 
      if ($fext != &#39;csv&#39;) { 
        die(&#39;请上传csv格式的文件&#39;,HTTP_REFERER); 
      } 
      $handle = @fopen($_FILES[&#39;upfilename&#39;][&#39;tmp_name&#39;], "rb"); 
   
      $i = 0; 
      $import_type = &#39;&#39;; 
      if ($handle) 
      { 
        while($line_data = fgetcsv($handle, 4096, &#39;,&#39;)) 
        { 
          if ($i == 0) { 
            $import_type = trim($line_data[0]); 
            $i = 1; 
          } elseif (intval($line_data[0])) { 
            $line_list[] = $line_data; 
          } 
        } 
      } 
      //循环转换数据格式 
      foreach ($line_list as $i=> $v) 
      { 
        foreach ($v as $j=> $value) 
        { 
          $line_list[$i][$j] = iconv(&#39;GBK&#39;, &#39;UTF-8//IGNORE&#39;,$line_list[$i][$j]); 
        } 
      }//编码转换 
       
      fclose($handle); 
 
      if(!empty($line_list)) 
      { 
        // 登记号 
        $sn = array(); 
        $top_catid = 0; 
        $name = &#39;&#39;; 
        $func_name = &#39;&#39;; 
        switch ($import_type) { 
          case &#39;patent&#39;; 
          $top_catid = 5; 
          $name = &#39;专利申请号&#39;; 
          $func_name = &#39;deal_import_patent&#39;; 
          break; 
          case &#39;trademark&#39;; 
          $top_catid = 4; 
          $name = &#39;商标注册号&#39;; 
          $func_name = &#39;deal_import_trademark&#39;; 
          break; 
          case &#39;copyright&#39;; 
          $top_catid = 2185; 
          $name = &#39;登记号&#39;; 
          $func_name = &#39;deal_import_copyright&#39;; 
          break; 
          default: 
            die(&#39;上传文档未明确指定知产类型!&#39;); 
          break; 
        } 
        if ($import_type == &#39;patent&#39;) { 
          foreach($line_list as $lkey => $lval) { 
            $lval[2] = trim($lval[2]); 
            if ($lval[2] == &#39;专利技术&#39;) { 
              // 技术专利 
              if(!empty($lval[1])) { 
                if(in_array($lval[1],$sn)) 
                { 
                  die(&#39;列表中序号为&#39;.$lval[0].&#39;的知产的&#39;.$name.$lval[1].&#39;与前面的出现重复!&#39;);//判断是否有重复的数据(根据自己所需判断) 
                } 
                $sn[] = trim($lval[1]); 
              } else { 
                die(&#39;列表中序号为&#39;.$lval[0].&#39;的知产的&#39;.$name.&#39;为空!&#39;); 
              } 
            } else { 
              // 非技术专利 
              $line_list[$lkey][1] = &#39;&#39;; 
            } 
          } 
        } elseif ($import_type == &#39;trademark&#39;) { 
          foreach($line_list as $lkey => $lval) { 
            if(!empty($lval[1])) { 
              if(in_array($lval[1],$sn)) 
              { 
                die(&#39;列表中序号为&#39;.$lval[0].&#39;的知产的&#39;.$name.&#39;与前面的出现重复!&#39;); 
              } 
              $sn[] = $lval[1]; 
            } else { 
              die(&#39;列表中序号为&#39;.$lval[0].&#39;的知产的&#39;.$name.&#39;为空!&#39;); 
            } 
          } 
        } 
        if (!empty($sn)) { 
          $sql = &#39;SELECT serial_number FROM &#39; .$table_name. &#39; WHERE top_catid = &#39;.$top_catid.&#39; AND serial_number IN (\&#39;&#39; .implode("&#39;,&#39;", $sn). &#39;\&#39;)&#39;; 
          $result = $goods_db->query($sql); 
          $r = $goods_db->fetch_array(); 
          $exist = array(); 
          foreach ($r as $k=>$v){ 
            $exist[] = $v[&#39;serial_number&#39;]; 
          } 
           
          if (!empty($exist)) die($name.&#39;为:&#39;.implode(&#39;,&#39;,$exist).&#39;的知产已存在&#39;);//数据库中是否有相同的数据(根据自己所需判断) 
        }     
        // 调用处理函数 
        self::$func_name($line_list);//此时$line_list即为你上传文档的数据,数组格式,根据自己所需将数据导入数据库 
        die(&#39;批量导入完成!&#39;); 
      } 
       
    }

. The format of the .csv document is:

Related recommendations:

thinkPHP5 framework integrates plupload to implement pictures Batch upload

##Thinkphp5 PHPExcel implementation Batch uploadForm data function

##jQuery.Uploadify plugin implements a progress bar

Batch uploadImage function

The above is the detailed content of How to implement batch upload of data to database in php. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn