Compartir a través de


SqlBulkCopyColumnMappingCollection Clase

Definición

Colección de objetos SqlBulkCopyColumnMapping que hereda de CollectionBase.

public ref class SqlBulkCopyColumnMappingCollection sealed : System::Collections::CollectionBase
public sealed class SqlBulkCopyColumnMappingCollection : System.Collections.CollectionBase
type SqlBulkCopyColumnMappingCollection = class
    inherit CollectionBase
Public NotInheritable Class SqlBulkCopyColumnMappingCollection
Inherits CollectionBase
Herencia
SqlBulkCopyColumnMappingCollection

Ejemplos

En el ejemplo siguiente se copian de forma masiva datos de una tabla de origen en la base de datos de ejemplo AdventureWorks a una tabla de destino en la misma base de datos. Aunque el número de columnas del destino coincide con el número de columnas del origen, los nombres de columna y las posiciones ordinales no coinciden. SqlBulkCopyColumnMapping se agregan al SqlBulkCopyColumnMappingCollection objeto para que el SqlBulkCopy objeto cree un mapa de columnas para la copia masiva.

Importante

Este ejemplo no se ejecuta a menos que haya creado las tablas de trabajo como se describe en Configuración de ejemplos de copia masiva. Este código se proporciona para mostrar la sintaxis para usar SqlBulkCopy. Si las tablas de origen y destino están en la misma instancia de SQL Server, es más fácil y rápido usar una instrucción Transact-SQL INSERT … SELECT para copiar los datos.

using System;
using System.Data;
using Microsoft.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("ProductID", "ProdID");
                bulkCopy.ColumnMappings.Add("Name", "ProdName");
                bulkCopy.ColumnMappings.Add("ProductNumber", "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;";
    }
}

Comentarios

Las asignaciones de columnas definen la asignación entre el origen de datos y la tabla de destino.

Si no se definen asignaciones ( es decir, la ColumnMappings colección está vacía), las columnas se asignan implícitamente en función de la posición ordinal. Para que esto funcione, los esquemas de origen y destino deben coincidir. Si no lo hacen, se produce una InvalidOperationException excepción .

Si la ColumnMappings colección no está vacía, no es necesario especificar todas las columnas presentes en el origen de datos. Los que no están asignados por la colección se omiten.

Puede hacer referencia a las columnas de origen y de destino tanto por nombre como por ordinal. Puede mezclar referencias por nombre y columnas ordinales en la misma colección de asignaciones.

Propiedades

Item[Int32]

Obtiene el objeto SqlBulkCopyColumnMapping en el índice especificado.

Métodos

Add(Int32, Int32)

Crea un nuevo objeto SqlBulkCopyColumnMapping y lo agrega a la colección, utilizando las posiciones ordinales para especificar las columnas de origen y de destino.

Add(Int32, String)

Crea un nuevo objeto SqlBulkCopyColumnMapping y lo agrega a la colección, utilizando una posición ordinal para la columna de origen y una cadena para la columna de destino.

Add(SqlBulkCopyColumnMapping)

Agrega la asignación especificada a la colección SqlBulkCopyColumnMappingCollection.

Add(String, Int32)

Crea un nuevo objeto SqlBulkCopyColumnMapping y lo agrega a la colección, utilizando un nombre de columna para describir la columna de origen y una posición ordinal para especificar la columna de destino.

Add(String, String)

Crea un nuevo objeto SqlBulkCopyColumnMapping y lo agrega a la colección, utilizando nombres de columna para especificar las columnas de origen y de destino.

Clear()

Borra el contenido de la colección.

Contains(SqlBulkCopyColumnMapping)

Obtiene un valor que indica si existe un objeto SqlBulkCopyColumnMapping especificado en la colección.

CopyTo(SqlBulkCopyColumnMapping[], Int32)

Copia los elementos de SqlBulkCopyColumnMappingCollection en una matriz de elementos SqlBulkCopyColumnMapping, empezando en un índice concreto.

IndexOf(SqlBulkCopyColumnMapping)

Obtiene el índice del objeto SqlBulkCopyColumnMapping especificado.

Insert(Int32, SqlBulkCopyColumnMapping)

Inserta una nueva SqlBulkCopyColumnMapping en el índice especificado.

Remove(SqlBulkCopyColumnMapping)

Quita el elemento SqlBulkCopyColumnMapping especificado de la colección SqlBulkCopyColumnMappingCollection.

RemoveAt(Int32)

Quita de la colección la asignación en el índice especificado.

Se aplica a