Udostępnij za pośrednictwem


SqlBulkCopyColumnMapping Klasa

Definicja

Definiuje mapowanie między kolumną w SqlBulkCopy źródle danych wystąpienia a kolumną w tabeli docelowej wystąpienia.

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

Przykłady

Poniższy przykład zbiorczo kopiuje dane z tabeli źródłowej w przykładowej bazie danych AdventureWorks do tabeli docelowej w tej samej bazie danych. Chociaż liczba kolumn w miejscu docelowym jest zgodna z liczbą kolumn w źródle, a każda kolumna docelowa znajduje się w tej samej pozycji porządkowej co odpowiadająca jej kolumna źródłowa, nazwy kolumn nie są zgodne. SqlBulkCopyColumnMapping obiekty służą do tworzenia mapy kolumn dla kopii zbiorczej.

Ważne

Ten przykład nie zostanie uruchomiony, chyba że tabele robocze zostały utworzone zgodnie z opisem w temacie Konfiguracja przykładu kopiowania zbiorczego. Ten kod jest dostarczany w celu zademonstrowania składni tylko przy użyciu narzędzia SqlBulkCopy . Jeśli tabele źródłowe i docelowe znajdują się w tym samym wystąpieniu SQL Server, łatwiej i szybciej używać instrukcji Języka Transact-SQL INSERT … SELECT do kopiowania danych.

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 mapNumber =
                    new SqlBulkCopyColumnMapping("ProductNumber", "ProdNum");
                bulkCopy.ColumnMappings.Add(mapNumber);

                // 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;";
    }
}

Uwagi

Mapowania kolumn definiują mapowanie między źródłem danych a tabelą docelową.

Jeśli mapowania nie są zdefiniowane — czyli ColumnMappings kolekcja jest pusta — kolumny są mapowane niejawnie na podstawie położenia porządkowego. Aby to działało, schematy źródłowe i docelowe muszą być zgodne. Jeśli tego nie zrobią, InvalidOperationException zostanie zgłoszony.

ColumnMappings Jeśli kolekcja nie jest pusta, nie należy określać każdej kolumny w źródle danych. Te, które nie są mapowane przez kolekcję, są ignorowane.

Możesz odwoływać się do kolumn źródłowych i docelowych według nazwy lub porządkowej. Odwołania do kolumn według nazw i porządkowych można również mieszać w tej samej kolekcji mapowań.

Konstruktory

SqlBulkCopyColumnMapping()

Konstruktor bez parametrów, który inicjuje nowy SqlBulkCopyColumnMapping obiekt.

SqlBulkCopyColumnMapping(Int32, Int32)

Tworzy nowe mapowanie kolumn przy użyciu kolumn w celu odwoływania się do kolumn źródłowych i docelowych.

SqlBulkCopyColumnMapping(Int32, String)

Tworzy nowe mapowanie kolumn przy użyciu porządkowego kolumny w celu odwoływania się do kolumny źródłowej i nazwy kolumny docelowej.

SqlBulkCopyColumnMapping(String, Int32)

Tworzy nowe mapowanie kolumn przy użyciu nazwy kolumny w celu odwoływania się do kolumny źródłowej i porządkowej kolumny docelowej.

SqlBulkCopyColumnMapping(String, String)

Tworzy nowe mapowanie kolumn przy użyciu nazw kolumn w celu odwoływania się do kolumn źródłowych i docelowych.

Właściwości

DestinationColumn

Nazwa kolumny mapowanej w docelowej tabeli bazy danych.

DestinationOrdinal

Wartość porządkowa kolumny docelowej w tabeli docelowej.

SourceColumn

Nazwa kolumny mapowanej w źródle danych.

SourceOrdinal

Położenie porządkowe kolumny źródłowej w źródle danych.

Dotyczy