亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

從表中的列中刪除標識

從表中的列中刪除標識

回首憶惘然 2019-08-27 17:07:57
從表中的列中刪除標識我們有一個5GB的表(接近5億行),我們希望刪除其中一個列上的標識屬性,但是當我們嘗試通過SSMS執行此操作時 - 它會超時。這可以通過T-SQL完成嗎?
查看完整描述

3 回答

?
呼啦一陣風

TA貢獻1802條經驗 獲得超6個贊

IDENTITY一旦設置,您就無法刪除規范。

要刪除整個列:

ALTER TABLE yourTableDROP COLUMN yourCOlumn;

有關ALTER TABLE的信息

如果您需要保留數據,但刪除IDENTITY列,則需要:

  • 創建一個新列

  • 將數據從現有IDENTITY列傳輸到新列

  • 刪除現有IDENTITY列。

  • 將新列重命名為原始列名稱


查看完整回答
反對 回復 2019-08-27
?
慕的地6264312

TA貢獻1817條經驗 獲得超6個贊

如果您想在不添加和填充新列的情況下執行此操作,而無需重新排序列,并且幾乎沒有停機時間,因為表上沒有數據發生變化,讓我們使用分區功能做一些魔術(但由于沒有使用分區,所以不要需要企業版):

  1. 刪除所有指向此表的外鍵

  2. 腳本要創建的表; 重命名所有內容,例如'MyTable2','MyIndex2'等。刪除IDENTITY規范。

  3. 你現在應該有兩個“相同的” - 表,一個是完整的,另一個是空的,沒有IDENTITY。

  4. 跑 ALTER TABLE [Original] SWITCH TO [Original2]

  5. 現在您的原始表將為空,新表將具有數據。您已切換兩個表的元數據(即時)。

  6. 刪除原始(現在為空的表),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;


查看完整回答
反對 回復 2019-08-27
?
慕森王

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!


查看完整回答
反對 回復 2019-08-27
  • 3 回答
  • 0 關注
  • 607 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號