M
myusenetaccount
Hello all,
I'm looking for a bit of SqlBulkCopy advice for a web application that
appends large amounts of data into an existing SQL Server table.
SqlBulkCopy seems to be an excellent API for the task and it would
replace existing code that basicly iterated over a DataTable, calling a
SQL insert statement for each row, which I assume is a great deal
slower.
The problem I'm having is dealing with SqlBulkCopy errors that arise
when data type conversion fails or string truncation occures. I would
like the operation to continue and be notified of the problem rows so I
can programicly deal with them. For example, additional code would
replace values that failed data type conversion with BDNull.Values,
strings would be truncated and the insert would be manually preformed.
One of my thoughts was to set the batch size to say 1,000 and if a
batch fails, iternate over that section of the DataTable and manually
insert those rows. On the notify event I would remove the number of
rows equal to the batch size from the head of the DataTable this way
after an error occures I could resume a SqlBulkCopy operation at the
point the error occured. I suppose the effectiveness of this approach
is dependent upon the amount of bad data in the DataTable and guaging
the proper batch size.
My question is how sound is this approach and does anyone have
suggestions or alternative ideas?
Thank you,
- Harry
I'm looking for a bit of SqlBulkCopy advice for a web application that
appends large amounts of data into an existing SQL Server table.
SqlBulkCopy seems to be an excellent API for the task and it would
replace existing code that basicly iterated over a DataTable, calling a
SQL insert statement for each row, which I assume is a great deal
slower.
The problem I'm having is dealing with SqlBulkCopy errors that arise
when data type conversion fails or string truncation occures. I would
like the operation to continue and be notified of the problem rows so I
can programicly deal with them. For example, additional code would
replace values that failed data type conversion with BDNull.Values,
strings would be truncated and the insert would be manually preformed.
One of my thoughts was to set the batch size to say 1,000 and if a
batch fails, iternate over that section of the DataTable and manually
insert those rows. On the notify event I would remove the number of
rows equal to the batch size from the head of the DataTable this way
after an error occures I could resume a SqlBulkCopy operation at the
point the error occured. I suppose the effectiveness of this approach
is dependent upon the amount of bad data in the DataTable and guaging
the proper batch size.
My question is how sound is this approach and does anyone have
suggestions or alternative ideas?
Thank you,
- Harry