我正在尝试将行从一列复制到另一列。执行流程很简单。
- 检查列是否存在。
- 如果不是 - 添加列
- 定义光标并为新列填充行
- 将列设置为 NOT NULL。
不幸的是,我收到了这种类型的错误。它说该列不存在。但我已经创建了它并提交了事务。可能是什么原因?谢谢!
消息 207,级别 16,状态 1,第 29 行
无效的列名称“Field_Name”。
代码:
begin transaction;
IF NOT EXISTS(SELECT * FROM sys.columns
WHERE Name = N'Field_Name' and Object_ID = Object_ID(N'dbo.Table_Name'))
BEGIN
ALTER TABLE [dbo].[Table_Name]
ADD [Field_Name] VARCHAR(255)
END
commit;
DECLARE
@var1 int,
@var2 varchar(255)
DECLARE copy_cursor CURSOR FOR
SELECT id, Name
FROM Table_Name
OPEN copy_cursor
FETCH NEXT FROM copy_cursor
INTO @var1, @var2
WHILE @@FETCH_STATUS = 0
BEGIN
UPDATE Table_Name
SET Field_Name = @var2
WHERE id = @var1
FETCH NEXT FROM copy_cursor
INTO @var1, @var2
END
CLOSE copy_cursor;
DEALLOCATE copy_cursor;
ALTER TABLE Table_Name ALTER COLUMN Field_name varchar(255) NOT NULL