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开发手册中有相应的回滚例子。