我需要创建一个新的表,其中有外键与Users表。
Users表有两百万条记录。
当我在我们的测试服务器上运行脚本时,它锁定了这个表,并且测试用户在事务期间不能查询这个表。
查询开始于;
BEGIN TRANSACTION
GO
ALTER TABLE dbo.Users SET (LOCK_ESCALATION = TABLE)
GO
COMMIT
/*CREATE NEW TABLE AND FOREIGN KEYS HERE*/怎样才能在生产环境中安全地运行而不锁定它呢?
我们是否应该将生产服务器设置为“维护模式”,并在sql事务完成时再次将其设置为活动状态?
发布于 2013-04-09 08:46:41
要创建一个新表及其外键,甚至创建新的表索引,您不需要锁定或设置所引用的表的lock_escalation (在本例中为dbo.Users)。不要运行上面的事务,只运行新表和外键的创建。
https://stackoverflow.com/questions/15891035
复制相似问题