Các lỗi xảy ra do quá trình biên dịch lại hàng loạt sau khi giải quyết tên bị trì hoãn không thể bị bắt ở cùng mức độ lỗi xảy ra. Một cách giải quyết là bọc DDL trong SQL động:
BEGIN TRY
EXEC(N'ALTER TABLE [dbo].[my_table_name] ADD PRIMARY KEY ([id]);');
END TRY
BEGIN CATCH
IF ERROR_NUMBER() = 1779
BEGIN
--handle expected errors
PRINT 'Primary Key already exists. ';
END
ELSE
BEGIN
--raise other unexpected errors
THROW;
END;
END CATCH;