在不锁定表的情况下更改 TABLE
在 MySQL 中执行 ALTER TABLE 操作时,表在持续时间内处于读锁定状态语句,可能会阻塞并发写入。如果对大型表执行此操作,INSERT 或 UPDATE 语句可能会长时间中断。有没有一种解决方案可以在不影响正在进行的更新的情况下执行“热变更”?
唯一的选择:手动操作
虽然 MySQL 缺乏对热变更的直接支持,但存在替代方案:手动复制许多 RDBMS 系统自动执行的功能。这涉及:
技术注意事项:
添加新字段会有效地修改表中的每一行。此过程需要对磁盘上的数据进行物理重组,类似于影响更大的大量 UPDATE 操作。字段级锁定比行级锁定更复杂,并且表范围的锁定并不总是可取的。
其他 RDBMS 解决方案:
虽然 MySQL 可能不会原生支持热更改,其他 RDBMS 系统可能提供此类功能。例如,PostgreSQL 允许分区表,可以单独更改分区表而不会影响其他分区。
以上是如何在不锁定表和不中断并发更新的情况下执行 MySQL'ALTER TABLE”操作?的详细内容。更多信息请关注PHP中文网其他相关文章!