我正在使用 SSMS 开发 SQL 脚本,它对数据库进行了一些更改:
USE MyDatabase;
BEGIN TRANSACTION;
-- some statements
PRINT(N'#1');
IF (EXISTS (SELECT * FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_SCHEMA = N'dbo' AND TABLE_NAME = N'Table1' AND COLUMN_NAME = 'Table2_Id'))
BEGIN
ALTER TABLE [dbo].[Table1] DROP CONSTRAINT [FK_Table1_Table2_Table2_Id];
ALTER TABLE [dbo].[Table1] DROP COLUMN [Table2_Id];
DROP TABLE [dbo].[Table2];
PRINT(N'Table2 was dropped.');
END
PRINT(N'#2');
IF (NOT EXISTS (SELECT * FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = N'dbo' AND TABLE_NAME = N'Table2'))
BEGIN
CREATE TABLE [dbo].[Table2]
(
[Id] INT NOT NULL PRIMARY KEY IDENTITY,
[Number] INT NOT NULL UNIQUE,
[Name] NVARCHAR(200) NOT NULL,
[RowVersion] TIMESTAMP NOT NULL
);
PRINT(N'Table2 was re-created.');
INSERT INTO [dbo].[Table2]([Number], [Name]) VALUES(-1, N'Default value');
PRINT(N'Default value was inserted in Table2.');
END
-- some statements
COMMIT TRANSACTION;
如果Table1
有一个名为 的列Table2_Id
,则数据库有两个表(Table1
和Table2
)以及它们之间的外键关系。在这种情况下,我需要:
- 删除外键关系
FK_Table1_Table2_Table2_Id
; - 删除外键列
Table1.Table2_Id
; - 下降
Table2
; - 使用新表模式重新创建
Table2
; - 在中插入一些默认值
Table2
。
当我尝试执行此脚本时,出现以下错误:
消息 207,级别 16,状态 1,第 262 行无效的列名称“数字”。
消息 207,级别 16,状态 1,第 262 行无效的列名称“名称”。
看起来 SQL Server 使用旧架构Table2
(确实没有这些列),但是如果表刚刚使用新架构创建,这怎么可能?
我究竟做错了什么?
服务器版本是 SQL Server 2012 (SP1) - 11.0.3128.0 (X64)。
更新。
我添加了PRINT
调用(参见上面的脚本)。消息窗口中没有任何内容,除了错误消息。所以,脚本没有被执行......这是怎么回事?