php使用PDO事务配合表格读取大量数据插入操作实现方法
发布:smiling 来源: PHP粉丝网 添加日期:2018-08-02 09:47:45 浏览: 评论:0
在处理大量数据的时候,或者同时对几个表操作,而这几个表的操作要求,要么都成功,要么都失败的时候,就需要用到事物,而PDO中提供的事物,一般可以满足需求。
本篇文章,只涉及一个小例子。
在向数据库导入一个表格的时候,难免Excel文件中存在部分错误,如果用常规方法,将会导致,一部分插入了数据库,一部分没有插入,会带了很大的不便。
- header("Content-Type: text/html; charset=utf-8");
- error_reporting(E_ALL ^ E_NOTICE);
- require_once'excel_reader2.php';//导入excel_reader文件
- $data=newSpreadsheet_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=newPDO($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();//执行插入操作
- } //phpfensi.com
- $pdo->commit();//执行事物的提交操作*/
- }catch(PDOException$e){
- die("Error!: ".$e->getMessage().'<br>');
- $pdo->rollBack();//执行事物的回滚操作
- }
补充:
异常模式将会创建一个PDOException,并设置errorCode属性,它可以将执行代码封装到一个try{}catch{}语句块中。未捕获的异常将会导致脚本中断,并显示堆栈跟踪让用户了解是哪里出现了问题。
除此之外:
警告模式会产生一个PHP警告,并设置errorCode属性。如果设置的是警告模式,那么除非明确的检查错误代码,否则程序将继续按照其方式运行。
在默认模式中设置PDOStatement对象的errorCode属性,但不进行其他任何操作。
Tags: 表格 事务 方法
相关文章
- ·PHPExcel导出excel表格的应用(2016-07-27)
- ·php+mysqli实现将数据库中一张表信息打印到表格里的方法(2021-05-09)
- ·MySql数据库查询结果用表格输出PHP代码示例(2021-05-17)
- ·php实现的后台表格分页功能示例(2021-08-15)
- ·PHP5.6读写excel表格文件操作示例(2021-11-11)
- ·adodb的事务处理咋没效果(2013-11-28)
- ·php事务回滚简单实现方法示例(2018-08-31)
- ·PHP中PDO的事务处理分析(2019-10-04)
- ·php事务的实现方法介绍(代码示例)(2020-01-03)
- ·php数据库事务遇到的问题解决(2020-02-15)
- ·php事务处理实例详解(2021-03-19)
- ·PHP使用Mysql事务实例解析(2021-04-11)
- ·php+mysqli事务控制实现银行转账实例(2021-05-09)
- ·php+Mysqli利用事务处理转账问题实例(2021-05-11)
- ·PHP+Mysql基于事务处理实现转账功能的方法(2021-06-09)
- ·PHP mysql事务问题实例分析(2021-07-06)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)