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


Posted in PHP onFebruary 16, 2017

本文实例讲述了php使用PDO事务配合表格读取大量数据插入操作实现方法。分享给大家供大家参考,具体如下:

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

关于事务的具体讲解,https://3water.com/article/105744.htm

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

在向数据库导入一个表格的时候,难免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 相关文章推荐
基于PHP+MySQL的聊天室设计
Oct 09 PHP
php桌面中心(四) 数据显示
Mar 11 PHP
php下使用以下代码连接并测试
Apr 09 PHP
php+mysql写的简单留言本实例代码
Jul 25 PHP
PHP将整个网站生成HTML纯静态网页的方法总结
Feb 05 PHP
PHP number_format() 函数定义和用法
Jun 01 PHP
PHP中实现获取IP和地理位置类分享
Feb 10 PHP
PHP实现二维数组根据key进行排序的方法
Dec 30 PHP
自制PHP框架之设计模式
May 07 PHP
Laravel中服务提供者和门面模式的入门介绍
Nov 06 PHP
php+redis实现商城秒杀功能
Nov 19 PHP
Laravel 修改验证异常的响应格式实例代码详解
May 25 PHP
php的PDO事务处理机制实例分析
Feb 16 #PHP
php使用include 和require引入文件的区别
Feb 16 #PHP
Yii2实现UploadedFile上传文件示例
Feb 15 #PHP
使用PHPMailer发送邮件实例
Feb 15 #PHP
php使用gd2绘制基本图形示例(直线、圆、正方形)
Feb 15 #PHP
php使用GD2绘制几何图形示例
Feb 15 #PHP
php使用Jpgraph创建柱状图展示年度收支表效果示例
Feb 15 #PHP
You might like
星际争霸任务指南——神族
2020/03/04 星际争霸
使用php+Ajax实现唯一校验实现代码[简单应用]
2011/11/29 PHP
php数组操作之键名比较与差集、交集赋值的方法
2014/11/10 PHP
WordPress中is_singular()函数简介
2015/02/05 PHP
JS 密码强度验证(兼容IE,火狐,谷歌)
2010/03/15 Javascript
jQuery学习笔记之jQuery的事件
2010/12/22 Javascript
分享9点个人认为比较重要的javascript 编程技巧
2015/04/27 Javascript
jquery简单实现外部链接用新窗口打开的方法
2015/05/30 Javascript
javascript中递归函数用法注意点
2015/07/30 Javascript
浅谈bootstrap源码分析之scrollspy(滚动侦听)
2016/06/06 Javascript
JavaScript实现移动端滑动选择日期功能
2016/06/21 Javascript
使用Javascript监控前端相关数据的代码
2016/10/27 Javascript
纯js实现页面返回顶部的动画(超简单)
2017/08/10 Javascript
详解基于vue-cli配置移动端自适应
2018/01/13 Javascript
PHPStorm中如何对nodejs项目进行单元测试详解
2019/02/28 NodeJs
vue中@change兼容问题详解
2019/10/25 Javascript
vue实现短信验证码输入框
2020/04/17 Javascript
Python的自动化部署模块Fabric的安装及使用指南
2016/01/19 Python
使用XML库的方式,实现RPC通信的方法(推荐)
2017/06/14 Python
如何在sae中设置django,让sae的工作环境跟本地python环境一致
2017/11/21 Python
Sanic框架应用部署方法详解
2018/07/18 Python
Python基于分析Ajax请求实现抓取今日头条街拍图集功能示例
2018/07/19 Python
python 实现手机自动拨打电话的方法(通话压力测试)
2019/08/08 Python
对Pytorch中nn.ModuleList 和 nn.Sequential详解
2019/08/18 Python
django model的update时auto_now不被更新的原因及解决方式
2020/04/01 Python
CSS 3.0文字悬停跳动特效代码
2020/10/26 HTML / CSS
Myprotein瑞士官方网站:运动营养和健身网上商店
2019/09/25 全球购物
附答案的Java面试题
2012/11/19 面试题
十一个高级MySql面试题
2014/10/06 面试题
大学生毕业求职简历的自我评价
2013/10/24 职场文书
社团文化节邀请函
2014/01/10 职场文书
小学科学教学反思
2014/01/26 职场文书
房屋买卖协议书范本
2014/09/27 职场文书
单位委托书格式范本
2014/09/29 职场文书
Python3 使用pip安装git并获取Yahoo金融数据的操作
2021/04/08 Python
Nginx如何限制IP访问只允许特定域名访问
2022/07/23 Servers