sql-server-2008 – 调整列的大小会锁定表吗?

前端之家收集整理的这篇文章主要介绍了sql-server-2008 – 调整列的大小会锁定表吗?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
如果我将列从nvarchar(2)更改为nvarchar(10)或将列从char(2)更改为nvarchar(10),会发生什么.这会锁定,重组表格还是在没有任何影响或停机的情况下完成工作?

我试图找到如果我改变一个列会发生什么,但我没有找到任何东西.它是一个大表,有一两列需要更改.它关于MS sql Server 2008 R2.

解决方法

最简单的方法是使用测试环境创建一个虚拟表,一些虚拟记录应用更改谈话,然后通过探查器跟踪操作.

或者更改SSMS中设计的表格中的表格,然后使用“生成更改脚本”按钮.当我将列从Char(2)更改为NVARCHAR(10)时.生成更改脚本生成以下内容

CREATE TABLE dbo.Tmp_t2
    (
    id int NULL,c1 nvarchar(50) NULL,c2 nvarchar(2) NULL
    )  ON [PRIMARY]
GO
ALTER TABLE dbo.Tmp_t2 SET (LOCK_ESCALATION = TABLE)
GO
IF EXISTS(SELECT * FROM dbo.t2)
     EXEC('INSERT INTO dbo.Tmp_t2 (id,c1,c2)
        SELECT id,CONVERT(nvarchar(50),c1),c2 FROM dbo.t2 WITH (HOLDLOCK TABLOCKX)')
GO
DROP TABLE dbo.t2
GO
EXECUTE sp_rename N'dbo.Tmp_t2',N't2','OBJECT' 
GO
COMMIT

猜你在找的MsSQL相关文章