sql-server-2008 – 调整列的大小会锁定表吗?
发布时间:2020-12-12 16:49:44 所属栏目:MsSql教程 来源:网络整理
导读:如果我将列从nvarchar(2)更改为nvarchar(10)或将列从char(2)更改为nvarchar(10),会发生什么.这会锁定,重组表格还是在没有任何影响或停机的情况下完成工作? 我试图找到如果我改变一个列会发生什么,但我没有找到任何东西.它是一个大表,有一两列需要更改.它关于
如果我将列从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 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- JBoss数据库连接池
- SqlServer 2008 出现mscorlib错误提示的解决办法
- sql-server – 模仿group_concat()与GROUP BY结合使用
- SQLServer 2005 MSG 2570 类型为"In-row data" 中。
- sql-server – 是RedGate SQL Source Control吗?
- linq-to-sql – Linq To SQL Group By和Sum
- sql-server – 使用SQL Server T-SQL错误处理的最佳实践是什
- SQLite教程(五):数据库和事务
- sql – 如何查找无向图的所有连接子图
- Instagram提升PostgreSQL性能的五个技巧