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 相关文章推荐
Mysql中limit的用法方法详解与注意事项
Apr 19 PHP
PHP Header用于页面跳转要注意的几个问题总结
Oct 03 PHP
探讨:使用XMLSerialize 序列化与反序列化
Jun 08 PHP
从零开始学YII2框架(三)扩展插件yii2-gird
Aug 20 PHP
Yii框架获取当前controlle和action对应id的方法
Dec 03 PHP
smarty内置函数config_load用法实例
Jan 22 PHP
php使用array_search函数实现数组查找的方法
Jun 12 PHP
thinkPHP中多维数组的遍历方法
Jan 09 PHP
PHP实现从PostgreSQL数据库检索数据分页显示及根据条件查找数据示例
Jun 09 PHP
PHP面向对象程序设计模拟一般面向对象语言中的方法重载(overload)示例
Jun 13 PHP
PHP中常用的三种设计模式详解【单例模式、工厂模式、观察者模式】
Jun 14 PHP
php实现网页上一页下一页翻页过程详解
Jun 28 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
php仿QQ验证码的实例分析
2013/07/01 PHP
php网页标题中文乱码的有效解决方法
2014/03/05 PHP
php使用curl和正则表达式抓取网页数据示例
2014/04/13 PHP
laravel学习教程之关联模型
2016/07/30 PHP
JQuery 学习技巧总结
2010/05/21 Javascript
javascript打印大全(打印页面设置/打印预览代码)
2013/03/29 Javascript
如何实现移动端浏览器不显示 pc 端的广告
2015/10/15 Javascript
javascript实现延时显示提示框特效代码
2016/04/27 Javascript
jquery easyUI中ajax异步校验用户名
2016/08/19 Javascript
浅谈js数组和splice的用法
2016/12/04 Javascript
es7学习教程之Decorators(修饰器)详解
2017/07/21 Javascript
JS点击图片弹出文件选择框并覆盖原图功能的实现代码
2017/08/25 Javascript
解决js ajax同步请求造成浏览器假死的问题
2018/01/18 Javascript
ExtJs整合Echarts的示例代码
2018/02/27 Javascript
详解vue-cli 构建项目 vue-cli请求后台接口 vue-cli使用axios、sass、swiper
2018/05/28 Javascript
AngularJS 监听变量变化的实现方法
2018/10/09 Javascript
vue-cli配置全局sass、less变量的方法
2019/06/06 Javascript
在微信小程序中使用vant的方法
2019/06/07 Javascript
JavaScript实现身份证验证代码实例
2019/08/26 Javascript
JavaScript获取页面元素的常用方法详解
2019/09/28 Javascript
JavaScript实现好看的跟随彩色气泡效果
2020/02/06 Javascript
jQuery 图片查看器插件 Viewer.js用法简单示例
2020/04/04 jQuery
[44:39]2014 DOTA2国际邀请赛中国区预选赛 NE VS CNB
2014/05/21 DOTA
[01:08:48]LGD vs OG 2018国际邀请赛淘汰赛BO3 第三场 8.25
2018/08/29 DOTA
Python3 queue队列模块详细介绍
2018/01/05 Python
python批量修改文件编码格式的方法
2018/05/31 Python
Python实现读取机器硬件信息的方法示例
2018/06/09 Python
python 获取url中的参数列表实例
2018/12/18 Python
Python lxml解析HTML并用xpath获取元素的方法
2019/01/02 Python
基于python实现获取网页图片过程解析
2020/05/11 Python
SISLEY希思黎官方旗舰店:享誉全球的奢华植物美容品牌
2018/04/25 全球购物
英国绿色商店:Natural Collection
2019/05/03 全球购物
领导的自我鉴定
2013/12/28 职场文书
2014年乡镇工作总结
2014/11/21 职场文书
2015年学校管理工作总结
2015/07/20 职场文书
利用JavaScript写一个简单计算器
2021/11/27 Javascript