如果我将列从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