InnoDB表事务和锁表是否可以一起用?

数据库   发布日期:2023年05月26日   浏览次数:299

经过自己的测试,必须是InnoDB表才能执行事务,MyISAM表不支持事务,事务和锁表不要一起用,因为unlock tables解锁表时会造成事务的提交,要不然可能达不预期,至少我自己测试是没有达到自己的设想。

//事务
$mysqli->query("BEGIN");//开启事务
$sql="insert into abc (title) values ('".date("H:i:s")."---此条为事务提交') ";
$mysqli->query($sql);
$mysqli->query("COMMIT");//"COMMIT","ROLLBACK"事务回滚

sleep(5);//此过程中等待5秒,刷新数据表可以看到之前事务提交是已经有数据的,表也可以刷新,但5秒后处理锁表卡死等待状态

//锁表
$mysqli->query("lock tables abc write");//多表锁定:lock tables abc write,bcd write");
$sql="insert into abc (title) values ('".date("H:i:s")."---此条为锁表写入') ";
$mysqli->query($sql);
sleep(10);
$mysqli->query("unlock tables");
exit;


以上就是InnoDB表事务和锁表是否可以一起用?的详细内容,更多关于InnoDB表事务和锁表是否可以一起用?的资料请关注九品源码其它相关文章!