Home > php教程 > php手册 > body text

ThinkPHP数据库驱动之mysql事物回滚

WBOY
Release: 2016-06-07 11:36:09
Original
1221 people have browsed it

很简单的一个事物回滚,简单介绍下事物回滚,示例怎么使用Thinkphp的回滚。下面上俩个由浅入深的例子。会给你帮助理解,和提升。
//具体的讲解请允许我把它放在了 http://www.ichasem.com/?p=331 这里
1、开启事务方法 startTrans()
2、事务提交方法 commit()
3、事务回滚方法 rollback()
用法例子:$order = M(‘order’);<br> $allAdded = true; //先设定一个值为 true;<br> $data['name'] = 'winter';<br> $order->startTrans(); //开启事物<br> for($i = 1;$i     $sign = $order->add($data); //添加一条数据到order表<br>     if(!$sign){<br>         $order->rollback(); //如果order添加失败事物回滚<br>         $allAdded = false; //并且把allAdded设置为 false<br>     }<br> }<br> <br> //回滚<br> if($allAdded){<br>     $order->commit(); <br>     // 如果allAdded为真则两条数据都成功;那么 commit事物提交<br>     echo '添加成功';<br> }else{<br>     echo '添加失败';<br> }小解析:如果commit了。那么就提交插入数据。如果发现alladded为假说明有条数据没插入正确。那么就rollback回滚就会取消事物开启之后操作数据库的所有行为。

winter在提供一个例子助于大家加深理解~public function insertdata(){<br>     $model = M();<br>     $model->startTrans();<br>     $data['name'] = 'winter';<br> //增加一条用户信息<br>     $si = $model->table(C('DB_PREFIX').'user')->add($data);<br>     if(!$si){<br>         $model->rollback();<br>         exit();<br>     }<br>     $car['brand'] = $si;<br> //增加一条用户id<br> <br>     $c = $model->table(C('DB_PREFIX').'car')->add($car);<br>     if($si && $c){<br>         $model->commit();<br>     }else{<br>         $model->rollback();<br>     }<br> }

AD:真正免费,域名+虚机+企业邮箱=0元

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Recommendations
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template