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