Questo articolo è stato tradotto automaticamente. Per visualizzare l'articolo in inglese, selezionare la casella di controllo Inglese. È possibile anche visualizzare il testo inglese in una finestra popup posizionando il puntatore del mouse sopra il testo.
Traduzione
Inglese

Metodo SqlBulkCopyColumnMappingCollection.Add (Int32, String)

 

Data di pubblicazione: ottobre 2016

Crea un nuovo SqlBulkCopyColumnMapping e lo aggiunge alla raccolta, utilizza un numero ordinale di colonna di origine e una stringa per la colonna di destinazione.

Spazio dei nomi:   System.Data.SqlClient
Assembly:  System.Data (in System.Data.dll)

public SqlBulkCopyColumnMapping Add(
	int sourceColumnIndex,
	string destinationColumn
)

Parametri

sourceColumnIndex
Type: System.Int32

La posizione ordinale della colonna di origine all'interno dell'origine dati.

destinationColumn
Type: System.String

Il nome della colonna di destinazione all'interno della tabella di destinazione.

Valore restituito

Type: System.Data.SqlClient.SqlBulkCopyColumnMapping

Un mapping di colonne.

Mapping di una raccolta devono essere uniformi: tutte le coppie intero/intero, tutte le coppie stringa/stringa, tutte le coppie/stringa di tipo integer o tutte le coppie stringa o integer. Se si tenta di aggiungere un mapping diverso da quelli già presenti nell'insieme, un InvalidOperationException viene generata un'eccezione.

Il seguente esempio di copia di massa da una tabella di origine di AdventureWorks database di esempio per una tabella di destinazione nello stesso database. Anche se il numero di colonne nella destinazione corrisponde al numero di colonne nell'origine, i nomi di colonna e le posizioni ordinali non corrispondono. SqlBulkCopyColumnMapping gli oggetti vengono utilizzati per creare una mappa per la copia di massa.

System_CAPS_importantImportante

Questo esempio non verrà eseguito a meno che le tabelle di lavoro non siano state create come descritto in Installazione dell'esempio relativo alla copia di massa. Il codice viene fornito solo per illustrare la sintassi relativa all'utilizzo di SqlBulkCopy. Se le tabelle di origine e destinazione sono nella stessa istanza di SQL Server, è più facile e rapido usare Transact-SQL INSERT … SELECT istruzione per copiare i dati.

using System.Data.SqlClient;

class Program
{
    static void Main()
    {
        string connectionString = GetConnectionString();
        // Open a sourceConnection to the AdventureWorks database.
        using (SqlConnection sourceConnection =
                   new SqlConnection(connectionString))
        {
            sourceConnection.Open();

            // Perform an initial count on the destination table.
            SqlCommand commandRowCount = new SqlCommand(
                "SELECT COUNT(*) FROM " +
                "dbo.BulkCopyDemoDifferentColumns;",
                sourceConnection);
            long countStart = System.Convert.ToInt32(
                commandRowCount.ExecuteScalar());
            Console.WriteLine("Starting row count = {0}", countStart);

            // Get data from the source table as a SqlDataReader.
            SqlCommand commandSourceData = new SqlCommand(
                "SELECT ProductID, Name, " +
                "ProductNumber " +
                "FROM Production.Product;", sourceConnection);
            SqlDataReader reader =
                commandSourceData.ExecuteReader();

            // Set up the bulk copy object. 
            using (SqlBulkCopy bulkCopy =
                       new SqlBulkCopy(connectionString))
            {
                bulkCopy.DestinationTableName =
                    "dbo.BulkCopyDemoDifferentColumns";

                // The column order in the source doesn't match the order 
                // in the destination, so ColumnMappings must be defined.
                bulkCopy.ColumnMappings.Add(0, "ProdID");
                bulkCopy.ColumnMappings.Add(1, "ProdName");
                bulkCopy.ColumnMappings.Add(2, "ProdNum");

                // Write from the source to the destination.
                try
                {
                    bulkCopy.WriteToServer(reader);
                }
                catch (Exception ex)
                {
                    Console.WriteLine(ex.Message);
                }
                finally
                {
                    // Close the SqlDataReader. The SqlBulkCopy
                    // object is automatically closed at the end
                    // of the using block.
                    reader.Close();
                }
            }

            // Perform a final count on the destination 
            // table to see how many rows were added.
            long countEnd = System.Convert.ToInt32(
                commandRowCount.ExecuteScalar());
            Console.WriteLine("Ending row count = {0}", countEnd);
            Console.WriteLine("{0} rows were added.", countEnd - countStart);
            Console.WriteLine("Press Enter to finish.");
            Console.ReadLine();
        }
    }

    private static string GetConnectionString()
        // To avoid storing the sourceConnection string in your code, 
        // you can retrieve it from a configuration file. 
    {
        return "Data Source=(local); " +
            " Integrated Security=true;" +
            "Initial Catalog=AdventureWorks;";
    }
}

.NET Framework
Disponibile da 2.0
Torna all'inizio
Mostra: