当前位置:首页 > PHP教程 > php应用 > 列表

php实现文本数据导入SQL SERVER

发布:smiling 来源: PHP粉丝网  添加日期:2021-05-26 22:10:12 浏览: 评论:0 

php将文本文件导入mysql我们经常遇到,但是如果是导入到sqlserver又应该如何操作呢,下面就给大家分享一下本人的操作方法,感觉效率还不错,这里推荐给大家。

我测试是支持的CSV,SQL,TXT

其实其他格式也可以,只不过我用不到而已

速度是差不多是每秒一万吧

  1. <?php 
  2. set_time_limit(0); 
  3. ignore_user_abort(true); 
  4. include('sgk.php'); 
  5. echo "<br><br>"
  6. ?> 
  7. <?php 
  8. function array_iconv($data,$output = 'GBK') { 
  9.  $encode_arr = array('UTF-8','ASCII','GBK','GB2312','BIG5','JIS','eucjp-win','sjis-win','EUC-JP'); 
  10.  $encoded = mb_detect_encoding($data$encode_arr);//自动判断编码 
  11.  if (!is_array($data)) { 
  12.  return mb_convert_encoding($data$output$encoded); 
  13.  } 
  14.  else { 
  15.  foreach ($data as $key=>$val) { 
  16.   if(is_array($val)) { 
  17.   $data[$key] = array_iconv($val$input$output); 
  18.   } else { 
  19.   $data[$key] = mb_convert_encoding($data$output$encoded); 
  20.   } 
  21.  } 
  22.  return $data
  23.  } 
  24. function microtime_float(){  
  25.   return microtime(true);  
  26. }  
  27. if ($_SESSION['id']<>''){ 
  28. if (@$_POST["submit"]<>""){ 
  29. if ((($_FILES["file"]["type"] == "text/plain"
  30. || ($_FILES["file"]["type"] == "application/vnd.ms-excel") || ($_FILES["file"]["type"] == "application/octet-stream"
  31. || ($_FILES["file"]["type"] == "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet")) 
  32. && ($_FILES["file"]["size"] < 198102805)) 
  33.  { 
  34.  if ($_FILES["file"]["error"] > 0) 
  35.   { 
  36.   echo "Return Code: " . $_FILES["file"]["error"] . "<br />"
  37.   } 
  38.  else 
  39.   { 
  40.   $name=$_FILES["file"]["name"]; 
  41.   $name=iconv('utf-8''GB2312//IGNORE'$_FILES['file']['name']);  
  42.   echo "Upload: " . $_FILES["file"]["name"] . "<br />"
  43.   echo "Size: " . ($_FILES["file"]["size"] / 1048576) . " Mb<br />"
  44.   $exitpathinfo($_FILES["file"]["name"], PATHINFO_EXTENSION); 
  45.   $exit='.' .$exit
  46.    
  47.     if ($exit==".asp" or $exit==".php" or $exit==".jsp" OR $exit==".aspx"){ 
  48.   echo "我擦,你想做什么?"
  49.   exit
  50.   } 
  51.   $size=filesize($_FILES["file"]["tmp_name"]); 
  52.    $_FILES["file"]["name"]=md5($_FILES["file"]["name"].$size).$exit
  53.   if (file_exists("uploadhehe/" . $_FILES["file"]["name"])) 
  54.    { 
  55.    echo $_FILES["file"]["name"] . " 已经存在 "
  56.    } 
  57.   else 
  58.    { 
  59.    move_uploaded_file($_FILES["file"]["tmp_name"], 
  60.    "uploadhehe/" . $_FILES["file"]["name"]); 
  61.    echo "<br>开始自动处理文件<br>"
  62.    $begin = microtime_float(); 
  63. $file="uploadhehe/" . $_FILES["file"]["name"]; 
  64. $handle = @fopen($file"r"); 
  65. //$handle=array_iconv('utf-8','gbk',$handle); 
  66. $total=0; 
  67. $over=0; 
  68. if ($handle) { 
  69.   $sql="INSERT INTO [dbo].[own_user_data1] ([Name],[Context],[md5],[data]) VALUES"
  70.   $num=0; 
  71.   $_FILES['file']['name']=iconv('utf-8''GB2312//IGNORE'$_FILES['file']['name']);  
  72.   while (!feof($handle)) { 
  73.     $buffer = fgets($handle, 2000); 
  74.     $buffer=str_replace("\n"""$buffer); 
  75.     $line_array=explode("\r\n"$buffer); 
  76.     $Context=htmlspecialchars(addslashes($line_array[0])); 
  77.     $Context=str_replace("'", ',', $Context); 
  78.     $Context=str_replace('"'','$Context); 
  79.     $Context=array_iconv($Context); 
  80.     $date=date('y-m-d h:i:s',time()); 
  81.     if($num<999){ 
  82.     $sql.="('{$name}','{$Context}','{$_FILES['file']['name']}','{$date}'),";  
  83.     }else
  84.     $sql.="('{$name}','{$Context}','{$_FILES['file']['name']}','{$date}')";  
  85.     $a=sqlsrv_query($conn,$sql); 
  86.     // if( $a === false ) { 
  87.    // die( print_r( sqlsrv_errors(), true)); 
  88. // } 
  89.     $num=0; 
  90.     $sql="INSERT INTO [dbo].[own_user_data1] ([Name],[Context],[md5],[data]) VALUES"
  91.    
  92.     }    
  93.     $num++;  
  94.     $total++; 
  95.    
  96.    } 
  97.  }  
  98. fclose($handle); 
  99. $sql1="INSERT INTO [dbo].[own_user_info] ([uid],[md5],[date],[name],[size],[gold]) VALUES ('{$_SESSION["id"]}','{$_FILES["file"]["name"]}','{$date}','{$name}','{$total}','1')"
  100. sqlsrv_query($conn,$sql1); 
  101. if$a === false ) { 
  102.    die( print_r( sqlsrv_errors(), true)); 
  103. //处理没有插入到数据库的记录 
  104. if(substr($sqlstrlen($sql)-1,1)==","){ 
  105.   $sql=substr($sql, 0,strlen($sql)-1); 
  106.   sqlsrv_query($conn,$sql); 
  107. $end = microtime_float(); 
  108. $time = $end-$begin
  109. echo "共导入{$total}条记录,耗时{$time}秒"
  110.    
  111.    } 
  112.   } 
  113.  } 
  114. else 
  115.  { 
  116.  echo "上传失败!"
  117.    
  118.  } 
  119. }else
  120.  header("Location: login.php");  
  121. ?> 

以上所述就是本文的全部内容了,希望大家能够喜欢。

Tags: php文本数据导入SQL

分享到: