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

2025-05-29 0 95

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

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

关于事务的具体讲解,https://www.zzvips.com/article/158474.html

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

在向数据库导入一个表格的时候,难免excel文件中存在部分错误,如果用常规方法,将会导致,一部分插入了数据库,一部分没有插入,会带了很大的不便。

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42
<?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程序设计有所帮助。

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 php使用PDO事务配合表格读取大量数据插入操作实现方法 https://www.kuaiidc.com/95602.html

相关文章

发表评论
暂无评论