php调用mysql回滚 自我总结

I still have lots more to work on.

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

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

对于查没什么关系。

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

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

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

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

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

php中代码如下:

<?php
header('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语句,并赋给result

if($result&&$result1){
	$mysql->commit();
}
else{
	$mysql->rollback();
	echo "回滚";
}

$mysql->autocommit(true);
$mysql->close();
?>

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值