Questo articolo è stato tradotto automaticamente. Per visualizzare l'articolo in inglese, selezionare la casella di controllo Inglese. È possibile anche visualizzare il testo inglese in una finestra popup posizionando il puntatore del mouse sopra il testo.
Traduzione
Inglese

Costruttore SqlBulkCopy (String)

 

Data di pubblicazione: ottobre 2016

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

Spazio dei nomi:   System.Data.SqlClient
Assembly:  System.Data (in System.Data.dll)

public SqlBulkCopy(
	string connectionString
)

Parametri

connectionString
Type: System.String

La stringa che definisce la connessione verrà aperta per l'uso da parte dell'istanza di SqlBulkCopy. Se la stringa di connessione non usa Integrated Security = true, è possibile usare SqlBulkCopy o SqlBulkCopy e SqlCredential per passare l'ID utente e la password in modo più sicuro che specificandoli come testo nella stringa di connessione.

La connessione viene chiusa automaticamente al termine dell'operazione di copia bulk.

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

Nell'applicazione console riportata di seguito viene illustrato come caricamento bulk dei dati tramite una connessione specificata come stringa. La connessione viene chiusa automaticamente quando il SqlBulkCopy istanza è chiusa.

In questo esempio, i dati di origine viene innanzitutto letta da una tabella di SQL Server in un SqlDataReader istanza. I dati di origine non deve trovarsi in SQL Server. è possibile utilizzare qualsiasi origine dati che può essere letti in un IDataReader o caricare in un DataTable.

System_CAPS_importantImportante

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

using System.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;";
    }
}

.NET Framework
Disponibile da 2.0
Torna all'inizio
Mostra: