我試圖通過檢查密鑰是否已經存在,插入一個外鍵到多個表中,如果沒有,它應該插入它。 但是,當我嘗試運行腳本時,即使所有單個命令都正常工作,它也會跳過整個插入部分。 (我用的MS SQL Server 2008中)如何用IF EXISTS/IF NOT EXISTS語句添加外鍵?
begin transaction;
declare @isid as nvarchar(50);
declare @fk as nvarchar(50);
declare @statement as VARCHAR(2000);
declare @db_cursor CURSOR;
set @db_cursor = cursor FOR SELECT Name FROM [sys.Component] order by Name;
open @db_cursor;
fetch next from @db_cursor into @isid;
while @@FETCH_STATUS = 0
begin
SELECT @fk = CONSTRAINT_NAME FROM INFORMATION_SCHEMA.REFERENTIAL_CONSTRAINTS
WHERE CONSTRAINT_NAME = 'FK_' + @isid + '_Firma';
if not exists (select @fk)
begin
print 'NULL: ' + @fk;
select @statement = 'ALTER TABLE ' + @isid + ' add constraint FK_' +
@isid + '_Firma FOREIGN KEY(FirmaCode) REFERENCES Firma(FirmaCode)';
exec(@statement);
end
print 'NOT NULL: ' + @fk;
fetch next from @db_cursor into @isid;
end
close @db_cursor;
commit transaction;
基本輸出我得到的是 'NOT NULL: FK_<TableName>_Firma
'
感謝您的幫助,您可以與我的問題提供。
最終你試圖FK的添加到您的所有數據庫表(我假設根據您上面的代碼每個人都有FirmaCode列)時不存在。我對嗎? – knkarthick24
@ knkarthick24並不是所有的表都有FirmaCode列,但是那些在sys.Component裏面,所以基本上我做insert語句的表都有FirmaCode列。其中一些已經有了外鍵,所以爲了避免錯誤,我首先檢查哪一列沒有外鍵。 – Edward