pdo中的事务处理具体介绍
事务(transaction)是由查询和/或更新语句的序列组成。 用 begin、start transaction开始一个事务,rollback 回滚事务,commit 提交事务。 在开始一个事务后,可以有若干个 sql 查询或更新语句,个 sql递交执行后,还应该有判断是否正确执行的语句,以确定下一步是否回滚,若都被正确执行则最后提交事务。事务一旦回滚,数据库则保持开始事务前状态。就好象一个被编辑的文件不存盘退出,自还是保持文件原来的样子。所以,事务可被视为原子操作,事务中的 sql,要么全部执行,要不一句都不执行。
在前两篇文章《pdo中错误处理的方法一-errorcode()方法》,《pdo中错误处理的方法二-errorinfo()方法》我们介绍了pdo中处理错误的方法,那么我们来具体介绍一下pdo中的事务处理~
在pdo 中同样可以实现事务处理的功能,其应用的方法如下:
(1) 开启事务——begintransaction()方法。
begintransaction()方法将关闭自动提交(autocommit)模式,直到事务提交或者回滚以后才恢复。
(2)提交事务——commit()方法
commit()方法完成事务的提交操作,成功返回true,否则返回false。
(3)事务回滚——rollback()方法
rollback()方法执行事务的回滚操作。
通过 prepare()和 execute()方法向数据库中添加数据,并且通过事务处理机制确保数据能够正确的添加到数据库中,具体步骤如下:
创建一个php文件,首先定义数据库连接参数,创建 try{...}catch{...}语句,在try{}语句中实例化 pdo构造函数,完成与数据库的连接,并且通过 begintransaction()方法开启事务,然后定义insert 添加语句,通过$_post[]方法获取表单中提交的数据,通过prepare()和 execute()方法向数据库中添加数据,并且通过commit(0方法完成事务的提交操作,最后 在catch{}语句中返回错误信息,并且通过 rollback()方法执行事务的回滚操作,具体代码如下:
<form action="3.php" name="form1" method="post">
用户名:<input type="text" name="username">
密码: <input type="password" name="password">
<input type="submit" name="submit" value="提交">
</form>
<?php
header("content-type:text/html; charset=utf-8"); //设置页面的编码格式
$name =$_post['username'];
$password =$_post['password'];
if($_post['username']!=""&&$_post['password']!=""){
$dbms = "mysql"; // 数据库的类型
$dbname ="php_cn"; //使用的数据库名称
$user = "root"; //使用的数据库用户名
$pwd = "root"; //使用的数据库密码
$host = "localhost"; //使用的主机名称
$dsn = "$dbms:host=$host;dbname=$dbname";
try{
$pdo=new pdo($dsn,$user,$pwd);//初始化一个pdo对象,就是创建了数据库连接对象$pdo
$pdo -> begintransaction(); //开始事务
$query="insert into `user`(username,password) values ('$name','$password')";//需要执行的sql语句
$res=$pdo->prepare($query);//准备查询语句
$res->execute(); //执行查询语句,并返回结果集
if($res->errorcode()){
echo "数据添加成功";
}else{
echo "数据添加失败";
}
$pdo->commit(); //执行事务的提交操作
}catch (pdoexception $e){
die("error!:".$e->getmessage().'<br>');
$pdo -> rollback(); //执行事务的回滚
}
}
?>
最后输出的结果如下:
看了我们上面介绍的事务处理,小伙伴是不是觉得很简单,大家可以联系一下,巩固一下自己所学的东西,下一篇我们将继续介绍pdo中的储存过程,具体请阅读《pdo中的存储过程的详细介绍》!
以上就是pdo中的事务处理具体介绍的详细内容。
