php使用PDO事务配合表格读取大量数据插入操作实现方法
php  /  管理员 发布于 7年前   165
本文实例讲述了php使用PDO事务配合表格读取大量数据插入操作实现方法。分享给大家供大家参考,具体如下: 在处理大量数据的时候,或者同时对几个表操作,而这几个表的操作要求,要么都成功,要么都失败的时候,就需要用到事物,而PDO中提供的事物,一般可以满足需求。 关于事务的具体讲解,105744.htm 本篇文章,只涉及一个小例子。 在向数据库导入一个表格的时候,难免excel文件中存在部分错误,如果用常规方法,将会导致,一部分插入了数据库,一部分没有插入,会带了很大的不便。 补充: 异常模式将会创建一个PDOException,并设置errorCode属性,它可以将执行代码封装到一个try{}catch{}语句块中。未捕获的异常将会导致脚本中断,并显示堆栈跟踪让用户了解是哪里出现了问题。 警告模式会产生一个PHP警告,并设置errorCode属性。如果设置的是警告模式,那么除非明确的检查错误代码,否则程序将继续按照其方式运行。 在默认模式中设置PDOStatement对象的errorCode属性,但不进行其他任何操作。 附: php-excel-reader本站下载地址: codes/67223.html 更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP基于pdo操作数据库技巧总结》、《php+Oracle数据库程序设计技巧总结》、《PHP+MongoDB数据库操作技巧大全》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》 希望本文所述对大家PHP程序设计有所帮助。setOutputEncoding('UTF-8');//设置编码格式$data->read("example.xls");//读取excel文档*/echo $hang=$data->sheets[0]['numRows']."行
";//读出一共几行echo $lie=$data->sheets[0]['numCols']."列
";//读出一共几列$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().'
'); $pdo->rollBack();//执行事物的回滚操作}
除此之外:您可能感兴趣的文章:
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号