对于事务官方定义相比已经看过很多;简单来说MySQL事务其实就是一组SQL语句的集合,它们是一根绳是的蚂蚱,要么都成功要么全军覆没;
需要注意的是在MySQL支持事务的数据库引擎只有Innodb。
使用事务处理一组SQL操作可以保证数据库的完整性。举个很常见的例子:
银行转账的业务:A用户给B用户转账1000
SQL1: A 用户 -1000;
SQL2:B 用户 +1000;
这两个SQL顺序执行,如果两个SQL都执行成功,那么意味着此处转账业务的成功;
如果SQL1执行成功,SQL2执行时出现异常。那么SQL1执行的结果是要回退的。要不然可就出大问题啦!
使用事务就可以保证SQL1和SQL2执行结果保持一致。
还有很重要的一点不得不提那就是高并发下的事务处理;共并发请教下事务操作可能会出现脏读、幻读、丢失更新的情况;需要调试事务的隔离级别进行相应处理
(事务隔离级别:可序列化(SERIALIZABLE)、可重复读(REPEATABLE_READ)、提交读(READ_COMMITTED])、未提交读(READ_UNCOMMITTED))
Copyright © 广州京杭网络科技有限公司 2005-2024 版权所有 粤ICP备16019765号
广州京杭网络科技有限公司 版权所有