MySQL香港高防服务器在事物中混合使用存储引擎

作者:港云互联 时间:2019-09-20

        MySQL香港高防服务器层不管理事务,事物是由下层的存储引擎实现的。所以在同一个事物中,使用多种存储引擎是不可靠的。


        如果在亊务中混合使用了事务型和非事务型的表(例如InnoDB和MyISAM表),在正常提交的倩况下不会有什么问题。


        但如果该亊务需要回滚,非事务型的表上的变更就无法撤销,这会导致数据库处于不一 致的状态,这种情况很难修复,事务的最终结果将无法确定。所以,为毎张表选择合适 的存储引擎非常重要。


        在非事务型的表上执行事务相关操作的时候,MySQL香港高防服务器通常不会发出提醒,也不会报错。 有时候只有回滚的时候才会发出一个警告:“某些非事务型的表上的变更不能被回滚”。 但大多数情况下,对非事务型表的操作都不会有提示。

香港高防服务器

隐士和显示锁定



        InnoDB采用的是两阶段锁定协议(two-phase locking protocol)。在事务执行过程中,随时都可以执行锁定,锁只有在执行COMMIT或者ROLLBACK的时候才会释放,并且所有的锁是在同一时刻被释放。前面描述的锁定都是隐式锁定,InnoDB会根据隔离级别在需要的时候自动加锁。



        另外,InnoDB也支持通过特定的语句进行显示锁定,这些语句不属于SQL规范:


(1)SELECT...LOCK IN SHARE MODE

(2)SELECT...FOR UPDAET


        MySQL香港高防服务器也支持LOCK TABLESUNLOCK TABLES语句,这是在香港高防服务器层实现的,和存储引擎无关。它们有自己的用途,但并不能替代事务处理。如果应用需要用到事务,还是应该选择事务型存储引擎。


        经常可以发现.应用已经将表从MyISAM转换到InnoDB,但还是显示式地使用LOCK TABLES语句。这不但没有必要 ,还会严重影响性能,实际上InnoDB的行级锁工作得更好。


        LOCK TABLES和事务之间相互影响的话.情况会变得非常复杂,在某些MySQL香港高防服务器租用版本中甚至会产生无法预料的结果,因此,建议除了事务中禁用了AUTOCOMMIT可以使用LOCK TABLES之外,其他任何时候鄯不要显式地执行LOCK TABLES,不管使用的是什么存储引擎。




新人注册,即送价值满880元现金劵

立即注册>>
客服 电话 反馈 活动 回顶部

服务热线

+852-5764-9835

1对1贴心服务,7X24小时热线