首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >生产服务器上的SQL ALTER TABLE SET (LOCK_ESCALATION = TABLE)

生产服务器上的SQL ALTER TABLE SET (LOCK_ESCALATION = TABLE)
EN

Stack Overflow用户
提问于 2013-04-09 07:53:20
回答 1查看 3K关注 0票数 1

我需要创建一个新的表,其中有外键与Users表。

Users表有两百万条记录。

当我在我们的测试服务器上运行脚本时,它锁定了这个表,并且测试用户在事务期间不能查询这个表。

查询开始于;

代码语言:javascript
复制
BEGIN TRANSACTION
GO
ALTER TABLE dbo.Users SET (LOCK_ESCALATION = TABLE)
GO
COMMIT
/*CREATE NEW TABLE AND FOREIGN KEYS HERE*/

怎样才能在生产环境中安全地运行而不锁定它呢?

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

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-04-09 08:46:41

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

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15891035

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档