使用SQLAlchemy查询MySQL数据库,我得到以下错误:
sqlalchemy.exc.OperationalError: (raised as a result of Query-invokedautoflush; consider using a session.no_autoflush block if this flush is occurring prematurely) (_mysql_exceptions.OperationalErrorexceeded; try restarting transac
根据,更新锁可以在需要写入的时候转换为独占锁。同时,三个锁(X、S和U)的兼容性可以参考下表。X S US ✗ ✓ ✓然而,在一些博客中提到,从MySQL 5.7开始就有一个SX锁,它实现了B-树上操作的文件并发(1977通过这些博客,我发现SX锁与update锁非常相似。例如,它们具有相同的兼容性表。
由于我找不到更多关于MySQL中SX锁的“正式”介绍
我在数据库中运行一些update查询,这些查询批量更新记录,还有一些更新每行。在某些时候,我看到MySQL连接队列变满,并且不允许更多到MySQL的连接。这意味着一些客户端连接锁定了行,而另一个连接正在尝试更新相同的记录,并等待锁被移除,因此连接堆积起来。我不知道是哪个查询在这么做,因为这是在瞬间发生的,我想通过show full processlist或其他方法来查看数据库中发生了什么。
除了更新应用程序中的一些逻辑,这是非常耗时的