经过自己的测试,必须是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表事务和锁表是否可以一起用?的资料请关注九品源码其它相关文章!