加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读