SQLBulkCopy con Identity Insert nella tabella di destinazione

c#-4.0 sqlbulkcopy sql-server-2008

Domanda

Sto cercando di inserire un elenco generico su SQL Server con SQLBulkCopy,

E ho problemi con il campo Identity

Voglio la mia tabella di destinazione per generare il campo dell'identità Come dovrei gestirlo, ecco il mio codice

using (var bulkCopy = new SqlBulkCopy(ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString))
                {
                    bulkCopy.BatchSize = (int)DetailLines;
                    bulkCopy.DestinationTableName = "dbo.tMyTable";

                    var table = new DataTable();
                    var props = TypeDescriptor.GetProperties(typeof(tBFFormularyStatusList))
                        //Dirty hack to make sure we only have system data types 
                        //i.e. filter out the relationships/collections
                                               .Cast<PropertyDescriptor>()
                                               .Where(propertyInfo => propertyInfo.PropertyType.Namespace.Equals("System"))
                                               .ToArray();
                    foreach (var propertyInfo in props)
                    {
                        bulkCopy.ColumnMappings.Add(propertyInfo.Name, propertyInfo.Name);
                        table.Columns.Add(propertyInfo.Name, Nullable.GetUnderlyingType(propertyInfo.PropertyType) ?? propertyInfo.PropertyType);
                    }

                    var values = new object[props.Length];
                    foreach (var item in myGenericList)
                    {
                        for (var i = 0; i < values.Length; i++)
                        {
                            values[i] = props[i].GetValue(item);
                        }

                        table.Rows.Add(values);
                    }

                    bulkCopy.WriteToServer(table);
                }

eccezione

Property accessor 'ID' on object 'ProcessFlatFiles.DetailsClass' threw the following exception:'Object does not match target type.'

Ho anche provato

using (var bulkCopy = new SqlBulkCopy(ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString, SqlBulkCopyOptions.KeepIdentity))
                {

Risposta accettata

Finalmente ho ottenuto questo ha funzionato in questo modo

    using (var bulkCopy = new SqlBulkCopy(ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString, SqlBulkCopyOptions.KeepNulls & SqlBulkCopyOptions.KeepIdentity))
                {
                    bulkCopy.BatchSize = (int)DetailLines;
                    bulkCopy.DestinationTableName = "dbo.myTable";
                    bulkCopy.ColumnMappings.Clear();
                    bulkCopy.ColumnMappings.Add("SourceColumnName", "DestinationColumnName");
                    bulkCopy.ColumnMappings.Add("SourceColumnName", "DestinationColumnName");
                    bulkCopy.ColumnMappings.Add("SourceColumnName", "DestinationColumnName");
                    bulkCopy.ColumnMappings.Add("SourceColumnName", "DestinationColumnName");
                    .
                    .
                    .
                    .
                    bulkCopy.ColumnMappings.Add("SourceColumnName", "DestinationColumnName");

                    bulkCopy.WriteToServer(datatable);
                }

Risposta popolare

So che questa è una vecchia domanda, ma ho pensato che valesse la pena aggiungere questa alternativa: (Se hai già uno schema corretto, puoi saltare 1,2,3)

  1. Esegui una semplice selezione TOP 1 dalla tabella per restituire un datatable con lo schema della tabella di destinazione
  2. Utilizzare il metodo Clone di DataTable per generare un datatable con lo stesso schema e nessun dato
  3. Inserisci i tuoi dati in questa tabella
  4. Eseguire WriteToServer di WriteToServer (se gli ordini di colonna corrispondono, è possibile leggere i valori di identità. Se l'opzione non è fornita nel costruttore di SqlBulkCopy, l'impostazione predefinita è di ignorare questi valori e lasciare che siano forniti dalla destinazione).

Il punto importante è che se le colonne sono nell'ordine corretto (incluse le colonne Identity), tutto viene gestito per te.



Autorizzato sotto: CC-BY-SA with attribution
Non affiliato con Stack Overflow
È legale questo KB? Sì, impara il perché
Autorizzato sotto: CC-BY-SA with attribution
Non affiliato con Stack Overflow
È legale questo KB? Sì, impara il perché