php调用mysql回滚 自我总结

来源:互联网 发布:淘宝装修神器书本 编辑:程序博客网 时间:2024/06/05 14:13

I still have lots more to work on.

不久前才第一次听到回滚这个词。

其实对数据库的增删改操作,尤其是关于金钱的操作要注意回滚。

对于查没什么关系。

当出现突发情况,如断电断网等。你消费了金额,如果没有回滚,银行数据库你的钱少了,但是店家却收不到你的钱。或者说店家收到你的钱,你银行数据库的钱没少。这个时候就需要回滚。

回滚的意思是如果你第一条插入成功,第二条插入失败,这时候回滚,第一条也会被取消,因为它们是属于一个事务,就是这意思。要么都成功,否则啥都不做

在php中,执行的代码,其实并不是执行,因为默认开启了自动提交,这个时候执行的代码,就成为了执行。

在使用回滚时,我们要先关闭自动提交

除非显式地开始一个事务,否则每个查询都被当做一个单独的事务自动执行。

php中代码如下:

<?phpheader('Content-type:text/json; charset=utf-8');//@ $db = mysqli_connect('localhost','root','');$mysql=new mysqli('localhost','root','','security');$mysql->set_charset('utf8');if(mysqli_connect_errno()){ echo "Error:Could not connect to mysqli database."; exit;}$mysql->autocommit(false);$p="UPDATE `rollback` SET `test`=11 WHERE id=1;";$p1="UPDATE `rollback` SET `test`=21 qWHERE id=2;";$result =$mysql->query($p);//执行$p的mysql语句,并赋给result$result1 =$mysql->query($p1);//执行$p的mysql语句,并赋给resultif($result&&$result1){$mysql->commit();}else{$mysql->rollback();echo "回滚";}$mysql->autocommit(true);$mysql->close();?>

thinkphp开发手册中有相应的回滚例子。

0 0
原创粉丝点击