Compartir a través de


SqlBulkCopyColumnMapping Clase

Definición

Define la asignación entre una columna en el origen de datos de una instancia de SqlBulkCopy y una columna en la tabla de destino de la instancia.

public ref class SqlBulkCopyColumnMapping sealed
public sealed class SqlBulkCopyColumnMapping
type SqlBulkCopyColumnMapping = class
Public NotInheritable Class SqlBulkCopyColumnMapping
Herencia
SqlBulkCopyColumnMapping

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 y cada columna de destino está en la misma posición ordinal que su columna de origen correspondiente, los nombres de columna no coinciden. SqlBulkCopyColumnMapping Los objetos se usan para crear 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";

                // Set up the column mappings by name.
                SqlBulkCopyColumnMapping mapID =
                    new SqlBulkCopyColumnMapping("ProductID", "ProdID");
                bulkCopy.ColumnMappings.Add(mapID);

                SqlBulkCopyColumnMapping mapName =
                    new SqlBulkCopyColumnMapping("Name", "ProdName");
                bulkCopy.ColumnMappings.Add(mapName);

                SqlBulkCopyColumnMapping mapMumber =
                    new SqlBulkCopyColumnMapping("ProductNumber", "ProdNum");
                bulkCopy.ColumnMappings.Add(mapMumber);

                // 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 producirá 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. También puede mezclar referencias por nombre y columnas ordinales en la misma colección de asignaciones.

Constructores

SqlBulkCopyColumnMapping()

Constructor sin parámetros que inicializa un nuevo objeto SqlBulkCopyColumnMapping.

SqlBulkCopyColumnMapping(Int32, Int32)

Crea una nueva asignación de columnas, utilizando los índices de columna para hacer referencia a las columnas de origen y a las de destino.

SqlBulkCopyColumnMapping(Int32, String)

Crea una nueva asignación de columnas, utilizando un índice de columna para hacer referencia a la columna de origen y un nombre de columna para hacer referencia a la columna de destino.

SqlBulkCopyColumnMapping(String, Int32)

Crea una nueva asignación de columnas, utilizando un nombre de columna para hacer referencia a la columna de origen y un índice de columna para hacer referencia a la columna de destino.

SqlBulkCopyColumnMapping(String, String)

Crea una nueva asignación de columnas, utilizando nombres de columna para hacer referencia a las columnas de origen y las de destino.

Propiedades

DestinationColumn

Nombre de la columna que se está asignando en la tabla de la base de datos de destino.

DestinationOrdinal

Valor ordinal de la columna de destino en la tabla de destino.

SourceColumn

Nombre de la columna que se está asignando en el origen de datos.

SourceOrdinal

Posición ordinal de la columna de origen dentro del origen de datos.

Se aplica a