SqlBulkCopy Costruttori

Definizione

Overload

SqlBulkCopy(SqlConnection)

Inizializza una nuova istanza della SqlBulkCopy classe utilizzando l'istanza aperta specificata di SqlConnection .

SqlBulkCopy(String)

Inizializza e apre una nuova istanza di SqlConnection in base all'oggetto fornitoconnectionString . Il costruttore usa SqlConnection per inizializzare una nuova istanza della classe SqlBulkCopy.

SqlBulkCopy(String, SqlBulkCopyOptions)

Inizializza e apre una nuova istanza di SqlConnection in base all'oggetto fornitoconnectionString . Il costruttore utilizza l'oggetto SqlConnection per inizializzare una nuova istanza della classe SqlBulkCopy. L'istanza SqlConnection si comporta in base alle opzioni fornite incopyOptions Parametro.

SqlBulkCopy(SqlConnection, SqlBulkCopyOptions, SqlTransaction)

Inizializza una nuova istanza della SqlBulkCopy classe utilizzando l'istanza aperta esistente fornita di SqlConnection . L'istanza SqlBulkCopy si comporta in base alle opzioni fornite incopyOptions Parametro. Se viene specificato un oggetto SqlTransaction non Null, le operazioni di copia verranno eseguite all'interno di tale transazione.

SqlBulkCopy(SqlConnection)

Inizializza una nuova istanza della SqlBulkCopy classe utilizzando l'istanza aperta specificata di SqlConnection .

public:
 SqlBulkCopy(Microsoft::Data::SqlClient::SqlConnection ^ connection);
public SqlBulkCopy (Microsoft.Data.SqlClient.SqlConnection connection);
new Microsoft.Data.SqlClient.SqlBulkCopy : Microsoft.Data.SqlClient.SqlConnection -> Microsoft.Data.SqlClient.SqlBulkCopy
Public Sub New (connection As SqlConnection)

Parametri

connection
SqlConnection

Istanza SqlConnection già aperta utilizzata per eseguire l'operazione di copia di massa. Se la stringa di connessione non usaIntegrated Security = true , è possibile usare SqlCredential per passare l'ID utente e la password in modo più sicuro rispetto a specificando l'ID utente e la password come testo nella stringa di connessione.

Esempio

L'applicazione console seguente illustra come eseguire il caricamento bulk dei dati usando una connessione già aperta. In questo esempio, viene usato un oggetto SqlDataReader per copiare i dati dalla tabella Production.Product del database AdventureWorks di SQL Server in una tabella simile dello stesso database. Questo esempio viene fornito solo per scopi dimostrativi. Non è possibile usare SqlBulkCopy per spostare i dati da una tabella a un'altra nello stesso database in un'applicazione di produzione. Si noti che non è necessario che i dati di origine si trovino in SQL Server. È possibile usare qualsiasi origine dati che può essere letta in un oggetto IDataReader o caricata in un oggetto DataTable.

Importante

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

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.BulkCopyDemoMatchingColumns;",
                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();

            // Open the destination connection. In the real world you would 
            // not use SqlBulkCopy to move data from one table to the other 
            // in the same database. This is for demonstration purposes only.
            using (SqlConnection destinationConnection =
                       new SqlConnection(connectionString))
            {
                destinationConnection.Open();

                // Set up the bulk copy object. 
                // Note that the column positions in the source
                // data reader match the column positions in 
                // the destination table so there is no need to
                // map columns.
                using (SqlBulkCopy bulkCopy =
                           new SqlBulkCopy(destinationConnection))
                {
                    bulkCopy.DestinationTableName =
                        "dbo.BulkCopyDemoMatchingColumns";

                    try
                    {
                        // Write from the source to the destination.
                        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;";
    }
}

Commenti

Poiché la connessione è già aperta quando l'istanza SqlBulkCopy viene inizializzata, la connessione rimane aperta dopo la chiusura dell'istanza SqlBulkCopy . Se l'argomento connection è Null, viene generata un'eccezione ArgumentNullException .

Si applica a

SqlBulkCopy(String)

Inizializza e apre una nuova istanza di SqlConnection in base all'oggetto fornitoconnectionString . Il costruttore usa SqlConnection per inizializzare una nuova istanza della classe SqlBulkCopy.

public:
 SqlBulkCopy(System::String ^ connectionString);
public SqlBulkCopy (string connectionString);
new Microsoft.Data.SqlClient.SqlBulkCopy : string -> Microsoft.Data.SqlClient.SqlBulkCopy
Public Sub New (connectionString As String)

Parametri

connectionString
String

Stringa che definisce la connessione che verrà aperta per essere utilizzata dall'istanza SqlBulkCopy. Se la stringa di connessione non usaIntegrated Security = true , è possibile usare SqlBulkCopy(SqlConnection) o SqlBulkCopy(SqlConnection, SqlBulkCopyOptions, SqlTransaction) e SqlCredential per passare l'ID utente e la password in modo più sicuro rispetto a specificando l'ID utente e la password come testo nella stringa di connessione.

Eccezioni

Se connectionString è una stringa vuota, viene generata un'eccezione ArgumentException .

Esempio

L'applicazione console seguente illustra come caricare in blocco i dati usando una connessione specificata come stringa. La connessione viene chiusa automaticamente quando l'istanza SqlBulkCopy viene chiusa. In questo esempio i dati di origine vengono letti prima da una tabella SQL Server a un'istanza SqlDataReader di . Non è necessario che i dati di origine si trovino in SQL Server. È possibile utilizzare qualsiasi origine dati che possa essere letta in un oggetto IDataReader o caricata in un oggetto DataTable.

Importante

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

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.BulkCopyDemoMatchingColumns;",
                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 a connection string. 
            // In the real world you would not use SqlBulkCopy to move
            // data from one table to the other in the same database.
            using (SqlBulkCopy bulkCopy =
                       new SqlBulkCopy(connectionString))
            {
                bulkCopy.DestinationTableName =
                    "dbo.BulkCopyDemoMatchingColumns";

                try
                {
                    // Write from the source to the destination.
                    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;";
    }
}

Commenti

La connessione viene chiusa automaticamente alla fine dell'operazione di copia bulk. Se connectionString è Null, viene generata un'eccezione ArgumentNullException . Se connectionString è una stringa vuota, viene generata un'eccezione ArgumentException .

Si applica a

SqlBulkCopy(String, SqlBulkCopyOptions)

Inizializza e apre una nuova istanza di SqlConnection in base all'oggetto fornitoconnectionString . Il costruttore utilizza l'oggetto SqlConnection per inizializzare una nuova istanza della classe SqlBulkCopy. L'istanza SqlConnection si comporta in base alle opzioni fornite incopyOptions Parametro.

public:
 SqlBulkCopy(System::String ^ connectionString, Microsoft::Data::SqlClient::SqlBulkCopyOptions copyOptions);
public SqlBulkCopy (string connectionString, Microsoft.Data.SqlClient.SqlBulkCopyOptions copyOptions);
new Microsoft.Data.SqlClient.SqlBulkCopy : string * Microsoft.Data.SqlClient.SqlBulkCopyOptions -> Microsoft.Data.SqlClient.SqlBulkCopy
Public Sub New (connectionString As String, copyOptions As SqlBulkCopyOptions)

Parametri

connectionString
String

Stringa che definisce la connessione che verrà aperta per essere utilizzata dall'istanza SqlBulkCopy. Se la stringa di connessione non usaIntegrated Security = true , è possibile usare SqlBulkCopy(SqlConnection) o SqlBulkCopy(SqlConnection, SqlBulkCopyOptions, SqlTransaction) e SqlCredential per passare l'ID utente e la password in modo più sicuro rispetto a specificando l'ID utente e la password come testo nella stringa di connessione.

copyOptions
SqlBulkCopyOptions

Combinazione dei valori dell'enumerazione SqlBulkCopyOptions che determina quali righe dell'origine dati verranno copiate nella tabella di destinazione.

Esempio

L'applicazione console seguente illustra come eseguire un caricamento bulk usando una connessione specificata come stringa. Un'opzione è impostata per usare il valore nella colonna Identity della tabella di origine quando si carica la tabella di destinazione. In questo esempio i dati di origine vengono letti prima da una tabella SQL Server a un'istanza SqlDataReader di . La tabella di origine e la tabella di destinazione includono ogni colonna Identity. Per impostazione predefinita, viene generato un nuovo valore per la colonna Identity nella tabella di destinazione per ogni riga aggiunta. In questo esempio viene impostata un'opzione quando viene aperta la connessione che impone al processo di caricamento bulk di usare invece i valori Identity della tabella di origine. Per vedere come l'opzione modifica il funzionamento del caricamento bulk, eseguire l'esempio con dbo. Tabella BulkCopyDemoMatchingColumns vuota. Tutte le righe vengono caricate dall'origine. Eseguire quindi di nuovo l'esempio senza svuotare la tabella. Viene generata un'eccezione e il codice scrive un messaggio nella console per notificare che le righe non sono state aggiunte a causa di violazioni dei vincoli di chiave primaria.

Importante

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

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.BulkCopyDemoMatchingColumns;",
                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();

            // Create the SqlBulkCopy object using a connection string 
            // and the KeepIdentity option. 
            // In the real world you would not use SqlBulkCopy to move
            // data from one table to the other in the same database.
            using (SqlBulkCopy bulkCopy =
                new SqlBulkCopy(connectionString, SqlBulkCopyOptions.KeepIdentity))
            {
                bulkCopy.DestinationTableName =
                    "dbo.BulkCopyDemoMatchingColumns";

                try
                {
                    // Write from the source to the destination.
                    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;";
    }
}

Commenti

È possibile ottenere informazioni dettagliate su tutte le opzioni di copia bulk nell'argomento SqlBulkCopyOptions .

Si applica a

SqlBulkCopy(SqlConnection, SqlBulkCopyOptions, SqlTransaction)

Inizializza una nuova istanza della SqlBulkCopy classe utilizzando l'istanza aperta esistente fornita di SqlConnection . L'istanza SqlBulkCopy si comporta in base alle opzioni fornite incopyOptions Parametro. Se viene specificato un oggetto SqlTransaction non Null, le operazioni di copia verranno eseguite all'interno di tale transazione.

public:
 SqlBulkCopy(Microsoft::Data::SqlClient::SqlConnection ^ connection, Microsoft::Data::SqlClient::SqlBulkCopyOptions copyOptions, Microsoft::Data::SqlClient::SqlTransaction ^ externalTransaction);
public SqlBulkCopy (Microsoft.Data.SqlClient.SqlConnection connection, Microsoft.Data.SqlClient.SqlBulkCopyOptions copyOptions, Microsoft.Data.SqlClient.SqlTransaction externalTransaction);
new Microsoft.Data.SqlClient.SqlBulkCopy : Microsoft.Data.SqlClient.SqlConnection * Microsoft.Data.SqlClient.SqlBulkCopyOptions * Microsoft.Data.SqlClient.SqlTransaction -> Microsoft.Data.SqlClient.SqlBulkCopy
Public Sub New (connection As SqlConnection, copyOptions As SqlBulkCopyOptions, externalTransaction As SqlTransaction)

Parametri

connection
SqlConnection

Istanza SqlConnection già aperta utilizzata per eseguire la copia di massa. Se la stringa di connessione non usaIntegrated Security = true , è possibile usare SqlCredential per passare l'ID utente e la password in modo più sicuro rispetto a specificando l'ID utente e la password come testo nella stringa di connessione.

copyOptions
SqlBulkCopyOptions

Combinazione dei valori dell'enumerazione SqlBulkCopyOptions che determina quali righe dell'origine dati verranno copiate nella tabella di destinazione.

externalTransaction
SqlTransaction

Istanza SqlTransaction esistente nella quale ha luogo la copia di massa.

Commenti

Se le opzioni includono UseInternalTransaction e l'argomento externalTransaction non è Null, viene generata un'eccezione InvalidArgumentException .

Per esempi che illustrano come usare SqlBulkCopy in una transazione, vedere Operazioni di copia bulk e transazioni.

Vedi anche

Si applica a