PDO事物配合表格读取大量插入,亲测可用

Posted diligentyang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PDO事物配合表格读取大量插入,亲测可用相关的知识,希望对你有一定的参考价值。

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

     关于事物的具体讲解,http://blog.csdn.net/qq_28602957/article/details/51039277

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

     在向数据库导入一个表格的时候,难免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属性,但不进行其他任何操作。



以上是关于PDO事物配合表格读取大量插入,亲测可用的主要内容,如果未能解决你的问题,请参考以下文章

springboot项目 从FTP服务器下载文件到本地,并读取文件中的内容代码示例(亲测可用)

JTidy解决中文乱码问题(亲测可用)

Springboot 热部署问题。亲测可用。

PDO 不能在 Access 数据库中插入新记录,但可以在同一个连接中读取和删除

PDO json插入多个标签

SQLSTATE[HY000] [2002] 资源暂时不可用 - mysql - innodb 和 pdo