SQL ALTER TABLE SET (LOCK_ESCALATION = TABLE) on production



我需要创建一个具有Users表外键的新表。

Users表有200万条记录

当我在测试服务器上运行脚本时,它会锁定该表,并且测试用户无法在事务期间查询该表。

查询以;

开头
BEGIN TRANSACTION
GO
ALTER TABLE dbo.Users SET (LOCK_ESCALATION = TABLE)
GO
COMMIT
/*CREATE NEW TABLE AND FOREIGN KEYS HERE*/

在没有锁定的情况下在生产环境中安全运行的方法是什么?

我们是否应该将生产服务器设置为"维护模式",并在sql事务完成时再次设置为活动模式?

对于创建新表及其外键,甚至新表索引,您不需要锁定或设置所引用表(在您的示例中为dbo.Users)的lock_escalation。不运行上面的事务,只运行新表和外键创建。

最新更新