3 回答

TA貢獻1802條經驗 獲得超6個贊
IDENTITY
一旦設置,您就無法刪除規范。
要刪除整個列:
ALTER TABLE yourTableDROP COLUMN yourCOlumn;
有關ALTER TABLE的信息
如果您需要保留數據,但刪除IDENTITY
列,則需要:
創建一個新列
將數據從現有
IDENTITY
列傳輸到新列刪除現有
IDENTITY
列。將新列重命名為原始列名稱

TA貢獻1817條經驗 獲得超6個贊
如果您想在不添加和填充新列的情況下執行此操作,而無需重新排序列,并且幾乎沒有停機時間,因為表上沒有數據發生變化,讓我們使用分區功能做一些魔術(但由于沒有使用分區,所以不要需要企業版):
刪除所有指向此表的外鍵
腳本要創建的表; 重命名所有內容,例如'MyTable2','MyIndex2'等。刪除IDENTITY規范。
你現在應該有兩個“相同的” - 表,一個是完整的,另一個是空的,沒有IDENTITY。
跑
ALTER TABLE [Original] SWITCH TO [Original2]
現在您的原始表將為空,新表將具有數據。您已切換兩個表的元數據(即時)。
刪除原始(現在為空的表),
exec sys.sp_rename
將各種模式對象重命名為原始名稱,然后可以重新創建外鍵。
例如,給定:
CREATE TABLE Original
(
Id INT IDENTITY PRIMARY KEY
, Value NVARCHAR(300)
);
CREATE NONCLUSTERED INDEX IX_Original_Value ON Original (Value);
INSERT INTO Original
SELECT 'abcd'
UNION ALL
SELECT 'defg';
您可以執行以下操作:
--create new table with no IDENTITY
CREATE TABLE Original2
(
Id INT PRIMARY KEY
, Value NVARCHAR(300)
);
CREATE NONCLUSTERED INDEX IX_Original_Value2 ON Original2 (Value);
--data before switch
SELECT 'Original', *
FROM Original
UNION ALL
SELECT 'Original2', *
FROM Original2;
ALTER TABLE Original SWITCH TO Original2;
--data after switch
SELECT 'Original', *
FROM Original
UNION ALL
SELECT 'Original2', *
FROM Original2;
--clean up
DROP TABLE Original;
EXEC sys.sp_rename 'Original2.IX_Original_Value2', 'IX_Original_Value', 'INDEX';
EXEC sys.sp_rename 'Original2', 'Original', 'OBJECT';
UPDATE Original
SET Id = Id + 1;
SELECT *
FROM Original;

TA貢獻1777條經驗 獲得超3個贊
這會受到外鍵和主鍵約束的影響,所以這里有一些腳本可以幫助你:
首先,創建一個具有臨時名稱的重復列:
alter table yourTable add tempId int NOT NULL default -1;update yourTable set tempId = id;
接下來,獲取主鍵約束的名稱:
SELECT * FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS WHERE TABLE_NAME = 'yourTable';
現在嘗試刪除列的主鍵約束:
ALTER TABLE yourTable DROP CONSTRAINT PK_yourTable_id;
如果你有外鍵,它將失敗,所以如果這樣,刪除外鍵約束。 保持記錄表明你已經開始運行,因此你可以再添加限制因素!
SELECT * FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS WHERE TABLE_NAME = 'otherTable';alter table otherTable drop constraint fk_otherTable_yourTable;commit;..
刪除所有外鍵約束后,您將能夠刪除PK約束,刪除該列,重命名臨時列,并將PK約束添加到該列:
ALTER TABLE yourTable DROP CONSTRAINT PK_yourTable_id;alter table yourTable drop column id;EXEC sp_rename 'yourTable.tempId', 'id', 'COLUMN';ALTER TABLE yourTable ADD CONSTRAINT PK_yourTable_id PRIMARY KEY (id) commit;
最后,添加FK約束:
alter table otherTable add constraint fk_otherTable_yourTable foreign key (yourTable_id) references yourTable(id);..
El Fin!
添加回答
舉報