BULK INSERT
действа като поредица от отделни INSERT
изрази и по този начин, ако заданието е неуспешно, то не връща всички ангажирани вмъквания.
Може обаче да бъде поставен в рамките на транзакция, така че можете да направите нещо подобно:
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