Sé que esta publicación es antigua, pero me encontré con este mismo problema y finalmente descubrí una solución para determinar qué columna causaba el problema y lo informaba cuando era necesario. Finalmente descubrí que el colid que se devuelve en la SqlException no se basa en cero, por lo que necesita restar 1 para obtener el valor. Después de eso, se usa como índice de _sortedColumnMappings ArrayList de la instancia de SqlBulkCopy, no del índice de las asignaciones de columnas que se agregaron a la instancia de SqlBulkCopy. Una cosa a tener en cuenta es que SqlBulkCopy se detendrá en el primer error recibido, por lo que este puede no ser el único problema, pero al menos ayuda a resolverlo.
try
{
bulkCopy.WriteToServer(importTable);
sqlTran.Commit();
}
catch (SqlException ex)
{
if (ex.Message.Contains("Received an invalid column length from the bcp client for colid"))
{
string pattern = @"\d+";
Match match = Regex.Match(ex.Message.ToString(), pattern);
var index = Convert.ToInt32(match.Value) -1;
FieldInfo fi = typeof(SqlBulkCopy).GetField("_sortedColumnMappings", BindingFlags.NonPublic | BindingFlags.Instance);
var sortedColumns = fi.GetValue(bulkCopy);
var items = (Object[])sortedColumns.GetType().GetField("_items", BindingFlags.NonPublic | BindingFlags.Instance).GetValue(sortedColumns);
FieldInfo itemdata = items[index].GetType().GetField("_metadata", BindingFlags.NonPublic | BindingFlags.Instance);
var metadata = itemdata.GetValue(items[index]);
var column = metadata.GetType().GetField("column", BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance).GetValue(metadata);
var length = metadata.GetType().GetField("length", BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance).GetValue(metadata);
throw new DataFormatException(String.Format("Column: {0} contains data with a length greater than: {1}", column, length));
}
throw;
}
Esto funciona muy bien, gracias por sumisión. – Steven
¿Sabes si también es posible obtener la fila nr? –
¿De dónde obtiene DataFormatException? ¿Es esta una clase local para tu proyecto? Además, su código se come todas las demás excepciones sql ... tal vez hacer un nuevo lanzamiento? – OmegaMan