SqlBulkCopyColumnMapping Klasa
Definicja
Ważne
Niektóre informacje odnoszą się do produktu w wersji wstępnej, który może zostać znacząco zmodyfikowany przed wydaniem. Firma Microsoft nie udziela żadnych gwarancji, jawnych lub domniemanych, w odniesieniu do informacji podanych w tym miejscu.
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. |