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

php使用PDO事务配合表格读取大量数据插入操作实现方法

发布:smiling 来源: PHP粉丝网  添加日期:2018-08-02 09:47:45 浏览: 评论:0 

在处理大量数据的时候,或者同时对几个表操作,而这几个表的操作要求,要么都成功,要么都失败的时候,就需要用到事物,而PDO中提供的事物,一般可以满足需求。

本篇文章,只涉及一个小例子。

在向数据库导入一个表格的时候,难免Excel文件中存在部分错误,如果用常规方法,将会导致,一部分插入了数据库,一部分没有插入,会带了很大的不便。

  1. header("Content-Type: text/html; charset=utf-8"); 
  2. error_reporting(E_ALL ^ E_NOTICE); 
  3. require_once'excel_reader2.php';//导入excel_reader文件 
  4. $data=newSpreadsheet_Excel_Reader();//创建对象 
  5. $data->setOutputEncoding('UTF-8');//设置编码格式 
  6. $data->read("example.xls");//读取excel文档*/ 
  7. echo$hang=$data->sheets[0]['numRows']."行<br>";//读出一共几行 
  8. echo$lie=$data->sheets[0]['numCols']."列<br>";//读出一共几列 
  9. $dbms='mysql'
  10. $dbname='biaoge'
  11. $user='root'
  12. $pwd='123456'
  13. $host='localhost'
  14. $dsn="$dbms:host=$host;dbname=$dbname"
  15. try{ 
  16.   $pdo=newPDO($dsn,$user,$pwd); 
  17.   $pdo->exec("SET NAMES UTF8");//设置数据库编码 
  18.   $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);//异常模式 
  19.   $pdo->beginTransaction();//开启事物 
  20.   $query="INSERT INTO test SET id1=?,id2=?,id3=?,id4=?,id5=?";//预编译插入语句 
  21.   $result=$pdo->prepare($query); 
  22. //  $result->execute(array("111","222","333","444","555")); 
  23. //  $pdo->commit(); 
  24.   for($i= 1;$i<=$hang;$i++) { 
  25.     $id1=$data->sheets[0]['cells'][$i][1]; 
  26.     $id2=$data->sheets[0]['cells'][$i][2]; 
  27.     $id3=$data->sheets[0]['cells'][$i][3]; 
  28.     $id4=$data->sheets[0]['cells'][$i][4]; 
  29.     $id5=$data->sheets[0]['cells'][$i][5]; 
  30.     $result->bindParam(1,$id1);//绑定参数 
  31.     $result->bindParam(2,$id2);//绑定参数 
  32.     $result->bindParam(3,$id3);//绑定参数 
  33.     $result->bindParam(4,$id4);//绑定参数 
  34.     $result->bindParam(5,$id5);//绑定参数 
  35.     echo$result->execute();//执行插入操作 
  36.   } //phpfensi.com 
  37.   $pdo->commit();//执行事物的提交操作*/ 
  38. }catch(PDOException$e){ 
  39.   die("Error!: ".$e->getMessage().'<br>'); 
  40.   $pdo->rollBack();//执行事物的回滚操作 

补充:

异常模式将会创建一个PDOException,并设置errorCode属性,它可以将执行代码封装到一个try{}catch{}语句块中。未捕获的异常将会导致脚本中断,并显示堆栈跟踪让用户了解是哪里出现了问题。

除此之外:

警告模式会产生一个PHP警告,并设置errorCode属性。如果设置的是警告模式,那么除非明确的检查错误代码,否则程序将继续按照其方式运行。

在默认模式中设置PDOStatement对象的errorCode属性,但不进行其他任何操作。

Tags: 表格 事务 方法

分享到: