BULK INSERT
działa jako seria pojedynczych INSERT
instrukcji, a zatem, jeśli zadanie się nie powiedzie, nie wycofuje wszystkich zatwierdzonych wstawek.
Można go jednak umieścić w transakcji, więc możesz zrobić coś takiego:
BEGIN TRANSACTION
BEGIN TRY
BULK INSERT OurTable
FROM 'c:\OurTable.txt'
WITH (CODEPAGE = 'RAW', DATAFILETYPE = 'char', FIELDTERMINATOR = '\t',
ROWS_PER_BATCH = 10000, TABLOCK)
COMMIT TRANSACTION
END TRY
BEGIN CATCH
ROLLBACK TRANSACTION
END CATCH