php使用PDO事务配合表格读取大量数据插入操作实现方法
程序员文章站
2024-03-07 14:01:15
本文实例讲述了php使用pdo事务配合表格读取大量数据插入操作实现方法。分享给大家供大家参考,具体如下:
在处理大量数据的时候,或者同时对几个表操作,而这几个表的操作要求...
本文实例讲述了php使用pdo事务配合表格读取大量数据插入操作实现方法。分享给大家供大家参考,具体如下:
在处理大量数据的时候,或者同时对几个表操作,而这几个表的操作要求,要么都成功,要么都失败的时候,就需要用到事物,而pdo中提供的事物,一般可以满足需求。
关于事务的具体讲解,
本篇文章,只涉及一个小例子。
在向数据库导入一个表格的时候,难免excel文件中存在部分错误,如果用常规方法,将会导致,一部分插入了数据库,一部分没有插入,会带了很大的不便。
<?php header("content-type: text/html; charset=utf-8"); error_reporting(e_all ^ e_notice); require_once 'excel_reader2.php';//导入excel_reader文件 $data = new spreadsheet_excel_reader();//创建对象 $data->setoutputencoding('utf-8');//设置编码格式 $data->read("example.xls");//读取excel文档*/ echo $hang=$data->sheets[0]['numrows']."行<br>";//读出一共几行 echo $lie=$data->sheets[0]['numcols']."列<br>";//读出一共几列 $dbms='mysql'; $dbname='biaoge'; $user='root'; $pwd='123456'; $host='localhost'; $dsn="$dbms:host=$host;dbname=$dbname"; try { $pdo = new pdo($dsn, $user, $pwd); $pdo->exec("set names utf8");//设置数据库编码 $pdo->setattribute(pdo::attr_errmode, pdo::errmode_exception);//异常模式 $pdo->begintransaction();//开启事物 $query = "insert into test set id1=?,id2=?,id3=?,id4=?,id5=?";//预编译插入语句 $result=$pdo->prepare($query); // $result->execute(array("111","222","333","444","555")); // $pdo->commit(); for ($i = 1; $i <= $hang; $i++) { $id1=$data->sheets[0]['cells'][$i][1]; $id2=$data->sheets[0]['cells'][$i][2]; $id3=$data->sheets[0]['cells'][$i][3]; $id4=$data->sheets[0]['cells'][$i][4]; $id5=$data->sheets[0]['cells'][$i][5]; $result->bindparam(1,$id1);//绑定参数 $result->bindparam(2,$id2);//绑定参数 $result->bindparam(3,$id3);//绑定参数 $result->bindparam(4,$id4);//绑定参数 $result->bindparam(5,$id5);//绑定参数 echo $result->execute();//执行插入操作 } $pdo->commit();//执行事物的提交操作*/ }catch (pdoexception $e){ die("error!: ".$e->getmessage().'<br>'); $pdo->rollback();//执行事物的回滚操作 }
补充:
异常模式将会创建一个pdoexception,并设置errorcode属性,它可以将执行代码封装到一个try{}catch{}语句块中。未捕获的异常将会导致脚本中断,并显示堆栈跟踪让用户了解是哪里出现了问题。
除此之外:
警告模式会产生一个php警告,并设置errorcode属性。如果设置的是警告模式,那么除非明确的检查错误代码,否则程序将继续按照其方式运行。
在默认模式中设置pdostatement对象的errorcode属性,但不进行其他任何操作。
附:
php-excel-reader本站下载地址:
更多关于php相关内容感兴趣的读者可查看本站专题:《php基于pdo操作数据库技巧总结》、《php+oracle数据库程序设计技巧总结》、《php+mongodb数据库操作技巧大全》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家php程序设计有所帮助。