事务是逻辑上的一组 *** 作,组成这组 *** 作的各个单元,要不全都成功要不全都失败,这个特性就是事务
注意:mysql数据支持事务,但是要求必须是innoDB存储引擎
解决这个问题:
mysql的事务解决这个问题,因为mysql的事务特性,要求这组 *** 作,要不全都成功,要不全都失败,这样就避免了某个 *** 作成功某个 *** 作失败。利于数据的安全
如何使用:
(1)在执行sql语句之前,我们要开启事务 start transaction
(2)正常执行我们的sql语句
(3)当sql语句执行完毕,存在两种情况:
1,全都成功,我们要将sql语句对数据库造成的影响提交到数据库中,committ
2,某些sql语句失败,我们执行rollback(回滚),将对数据库 *** 作赶紧撤销
(注意:mysql数据支持事务,但是要求必须是innoDB存储引擎)
mysql>create table bank(name varchar(20),money decimal(5,1))engine=innodb defau
lt charset=utf8
mysql>inset into bank values('shaotuo',1000),('laohu',5000)
mysql>select*from bank
+---------+--------+
| name | money |
+---------+--------+
| shaotuo | 1000.0 |
| laohu | 5000.0 |
+---------+--------+
------没有成功“回滚”执行rollback
mysql>start transaction//开启事务
Query OK, 0 rows affected (0.00 sec)
mysql>update bank set money=money+500 where name='shaotuo'
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql>update bank set moey=money-500 where name='laohu'
ERROR 1054 (42S22): Unknown column 'moey' in 'field list'
mysql>rollback//只要有一个不成功,执行rollback *** 作
Query OK, 0 rows affected (0.01 sec)
mysql>select*from bank
+---------+--------+
| name | money |
+---------+--------+
| shaotuo | 1000.0 |
| laohu | 5000.0 |
+---------+--------+
------成功之后 进行commit *** 作
mysql>start transaction//开启事务
Query OK, 0 rows affected (0.00 sec)
mysql>update bank set money=money+500 where name='shaotuo'
Query OK, 1 row affected (0.01 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql>update bank set money=money-500 where name='laohu'
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql>commit//两个都成功后执行commit(只要不执行commit,sql语句不会对真实的数据库造成影响)
Query OK, 0 rows affected (0.05 sec)
mysql>select*from bank
+---------+--------+
| name | money |
+---------+--------+
| shaotuo | 1500.0 |
| laohu | 4500.0 |
+---------+--------+
1. 普通事务以 begin / start transaction 开始,commit / rollback 结束的事务。或者是带有保存点 savepoint 的事务。
2. 链式事务
一个事务在提交的时候自动将上下文传给下一个事务,也就是说一个事务的提交和下一个事务的开始是原子性的,下一个事务可以看到上一个事务的处理结果。MySQL 的链式事务靠参数 completion_type 控制,并且回滚和提交的语句后面加上 work 关键词。
3. 嵌套事务
有多个 begin / commit / rollback 这样的事务块的事务,并且有父子关系。子事务的提交完成后不会真的提交,而是等到父事务提交才真正的提交。
4. 自治事务
内部事务的提交不随外部事务的影响,一般用作记录内部事务的异常情况。MySQL 不支持自治事务,但是某些场景可以用 MySQL 的插件式引擎来变相实现。
function func($val,$id) {$sql="update table set a=? where id=?"
$pre=$this->pdo->prepare($sql)
$this->pdo->beginTransaction()//开启事务
$bo=$pre->execute(array($val,$id))
if($bo){
//…执行代码……
$this->pdo->commit()//提交事务
return true
}else{
//…执行代码……
$this->pdo->rollBack()//回滚事务
return false
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)