Condividi tramite


Esecuzione di operazioni di copia bulk

La caratteristica di copia bulk di SQL Server supporta il trasferimento di grandi quantità di dati in o da una tabella o una vista di SQL Server. Il trasferimento dei dati può essere eseguito anche specificando un'istruzione SELECT. È possibile spostare i dati tra SQL Server e un file di dati del sistema operativo, ad esempio un file ASCII. Il file di dati può avere formati diversi. Per eseguire una copia bulk in un file di formato, è necessario definire il formato. I dati possono essere caricati in variabili di programma e trasferiti a SQL Server mediante metodi e funzioni di copia bulk.

In CodePlex è disponibile un'applicazione di esempio che illustra questa caratteristica; per ulteriori informazioni, vedere Esempi del Motore di database di SQL Server. In un'applicazione la copia bulk viene generalmente utilizzata in una delle modalità seguenti:

  • Copia bulk da una tabella, da una vista o dal set di risultati di un'istruzione Transact-SQL in un file di dati in cui i dati vengono archiviati nello stesso formato della tabella o della vista.

    Tale file viene definito file di dati in modalità nativa.

  • Copia bulk da una tabella, da una vista o dal set di risultati di un'istruzione Transact-SQL in un file di dati in cui i dati vengono archiviati in un formato diverso da quello della tabella o della vista.

    In questo caso viene creato un file di formato separato che definisce le caratteristiche (tipo di dati, posizione, lunghezza, carattere di terminazione e così via) di ogni colonna che viene archiviata nel file di dati. Se tutte le colonne vengono convertite in formato carattere, il file risultante viene definito file di dati in modalità carattere.

  • Copia bulk da un file di dati in una tabella o una vista.

    Se necessario, viene utilizzato un file di formato per determinare il layout del file di dati.

  • Caricare i dati in variabili di programma, quindi importarli in una tabella o in una vista utilizzando le funzioni di copia bulk per eseguire una copia bulk in una riga per volta.

Non è necessario che i file di dati utilizzati dalle funzioni di copia bulk vengano creati da un altro programma per la copia bulk. È possibile generare un file di dati e il file di formato in base alle definizioni della copia bulk in qualsiasi altro modo. Tali file possono essere quindi utilizzati con un programma per la copia bulk di SQL Server per importare i dati in SQL Server. È ad esempio possibile esportare dati da un foglio di calcolo in un file delimitato da tabulazione, compilare un file di formato che descrive il file delimitato da tabulazione, quindi utilizzare un programma per la copia bulk per importare rapidamente i dati in SQL Server. I file di dati generati dalla copia bulk possono essere importati anche in altre applicazioni. È ad esempio possibile utilizzare le funzioni di copia bulk per esportare i dati da una tabella o da una vista in un file delimitato da tabulazione che potrebbe quindi essere caricato in un foglio di calcolo.

Nota

A partire da SQL Server 2005, quando si utilizza l'utilità bcp, il server segnala un errore quando si verifica il troncamento dei dati numerici. In SQL Server 2000 e nelle versioni più recenti viene restituito solo un avviso. Ciò può comportare problemi per le applicazioni esistenti che ignorano l'avviso. Per evitare questi problemi, assicurarsi che i dati di input presentino valori corretti che non verranno troncati oppure continuare a utilizzare la versione SQL Server 2000 di bcp.

I programmatori che eseguono la codifica di applicazioni per l'utilizzo delle funzioni di copia bulk devono seguire le regole generali per garantire un buon livello di prestazioni per la copia bulk. Per ulteriori informazioni sul supporto per le operazioni di copia bulk in SQL Server, vedere Informazioni sulle operazioni di importazione ed esportazione bulk.

Limitazioni e restrizioni

Un tipo CLR definito dall'utente deve essere associato come dati binari. Anche se un file di formato specifica SQLCHAR come tipo di dati per una colonna con tipo definito dall'utente di destinazione, l'utilità BCP tratterà i dati come binari.

Non utilizzare SET FMTONLY OFF con le operazioni di copia bulk. SET FMTONLY OFF può compromettere la riuscita dell'operazione di copia bulk o determinare risultati imprevisti.

Provider OLE DB di SQL Server Native Client

Il provider OLE DB di SQL Server Native Client implementa due metodi per l'esecuzione di operazioni di copia bulk con un database di SQL Server. Il primo metodo comporta l'uso dell'interfaccia IRowsetFastLoad per le operazioni di copia bulk basate sulla memoria, mentre il secondo comporta l'uso dell'interfaccia IBCPSession per le operazioni di copia bulk basate su file.

Utilizzo di operazioni di copia bulk basate sulla memoria

Il provider OLE DB di SQL Server Native Client implementa l'interfaccia IRowsetFastLoad per esporre il supporto per le operazioni di copia bulk SQL Server basate sulla memoria. L'interfaccia IRowsetFastLoad implementa i metodi IRowsetFastLoad::Commit e IRowsetFastLoad::InsertRow.

Abilitazione di una sessione per IRowsetFastLoad

Il consumer notifica al provider OLE DB di SQL Server Native Client la necessità di eseguire la copia bulk impostando su VARIANT_TRUE la proprietà dell'origine dati SSPROP_ENABLEFASTLOAD specifica del provider OLE DB di SQL Server Native Client. Con la proprietà impostata sull'origine dati, il consumer crea una sessione del provider OLE DB di SQL Server Native Client. La nuova sessione consente al consumer di accedere all'interfaccia IRowsetFastLoad .

Nota

Se l'interfaccia IDataInitialize viene utilizzata per l'inizializzazione dell'origine dati, è necessario impostare la proprietà SSPROP_IRowsetFastLoad nel parametro rgPropertySets del metodo IOpenRowset::OpenRowset. In caso contrario, la chiamata al metodo OpenRowset restituirà E_NOINTERFACE.

L'abilitazione di una sessione per la copia bulk vincola il supporto del provider OLE DB di SQL Server Native Client per le interfacce nella sessione. Una sessione abilitata per la copia bulk espone solo le interfacce seguenti:

  • IDBSchemaRowset

  • IGetDataSource

  • IOpenRowset

  • ISupportErrorInfo

  • ITransactionJoin

Per disabilitare la creazione di set di righe abilitati per la copia bulk e fare in modo che la sessione del provider OLE DB di SQL Server Native Client ripristini l'elaborazione standard, reimpostare SSPROP_ENABLEFASTLOAD su VARIANT_FALSE.

Set di righe IRowsetFastLoad

I set di righe della copia bulk del provider OLE DB di SQL Server Native Client sono di sola scrittura ma espongono interfacce che consentono al consumer di determinare la struttura di una tabella SQL Server. Le interfacce seguenti sono esposte su un set di righe del provider OLE DB di SQL Server Native Client abilitato per la copia bulk:

  • IAccessor

  • IColumnsInfo

  • IColumnsRowset

  • IConvertType

  • IRowsetFastLoad

  • IRowsetInfo

  • ISupportErrorInfo

Le proprietà SSPROP_FASTLOADOPTIONS, SSPROP_FASTLOADKEEPNULLS e SSPROP_FASTLOADKEEPIDENTITY specifiche del provider controllano i comportamenti di un set di righe della copia bulk del provider OLE DB di SQL Server Native Client. Le proprietà vengono specificate nel membro rgProperties di un membro del parametro rgPropertySetsIOpenRowset .

ID proprietà

Descrizione

SSPROP_FASTLOADKEEPIDENTITY

Colonna: nessuna

L/S: Lettura/Scrittura

Tipo: VT_BOOL

Impostazione predefinita: VARIANT_FALSE

Descrizione: gestisce i valori Identity forniti dal consumer.

VARIANT_FALSE: i valori per una colonna Identity nella tabella SQL Server vengono generati da SQL Server. Qualsiasi valore associato per la colonna viene ignorato dal provider OLE DB di SQL Server Native Client.

VARIANT_TRUE: il consumer associa una funzione di accesso che fornisce un valore per una colonna Identity SQL Server. La proprietà Identity non è disponibile in colonne che supportano valori NULL, pertanto il consumer fornisce un valore univoco per ogni chiamata a IRowsetFastLoad::Insert.

SSPROP_FASTLOADKEEPNULLS

Colonna: nessuna

L/S: Lettura/Scrittura

Tipo: VT_BOOL

Impostazione predefinita: VARIANT_FALSE

Descrizione: gestisce valori NULL per le colonne con un vincolo DEFAULT. Ha effetto solo su colonne di SQL Server che supportano valori NULL e alle quali è applicato un vincolo DEFAULT.

VARIANT_FALSE: SQL Server inserisce il valore predefinito per la colonna quando il consumer del provider OLE DB di SQL Server Native Client inserisce una riga che contiene NULL per la colonna.

VARIANT_TRUE: SQL Server inserisce NULL per il valore di colonna quando il consumer del provider OLE DB di SQL Server Native Client inserisce una riga contenente NULL per la colonna.

SSPROP_FASTLOADOPTIONS

Colonna: nessuna

L/S: Lettura/Scrittura

Tipo: VT_BSTR

Impostazione predefinita: nessuna

Descrizione: questa proprietà corrisponde all'opzione -h "hint[,...n] " dell'utilità bcp. Di seguito sono indicate le stringhe che è possibile utilizzare come opzioni per l'esecuzione della copia bulk di dati in una tabella.

ORDER(column[ASC | DESC] [,...n]): ordinamento di dati nel file di dati. Le prestazioni della copia bulk vengono migliorate se il file di dati da caricare viene ordinato in base all'indice cluster della tabella.

ROWS_PER_BATCH = bb: numero di righe di dati per batch (come bb). Il server ottimizza il caricamento bulk in base al valore bb. Per impostazione predefinita, il valore ROWS_PER_BATCH è sconosciuto.

KILOBYTES_PER_BATCH = cc: numero di kilobyte (KB) di dati per batch (come cc). Per impostazione predefinita, KILOBYTES_PER_BATCH è sconosciuto.

TABLOCK: un blocco a livello di tabella viene acquisito per la durata dell'operazione di copia bulk. Questa opzione migliora in modo significativo le prestazioni, in quanto mantenere attivo un blocco solo per la durata dell'operazione di copia bulk riduce la contesa dei blocchi per la tabella. Una tabella può essere caricata contemporaneamente da più client se non include indici e si specifica TABLOCK. Per impostazione predefinita, il comportamento del blocco è determinato dall'opzione di tabella table lock on bulk load.

CHECK_CONSTRAINTS: eventuali vincoli su table_name vengono controllati durante l'operazione di copia bulk. Per impostazione predefinita, i vincoli vengono ignorati.

FIRE_TRIGGER: in SQL Server 2000 con i trigger abilitati la registrazione ottimizzata non è possibile, in quanto la logica del trigger è basata sui record di log. Durante un'operazione di importazione bulk con i trigger abilitati tutte le ottimizzazioni della registrazione bulk (inclusi i blocchi BU) sono disabilitate.

A partire da SQL Server 2005, in SQL Server viene tuttavia utilizzato il controllo delle versioni delle righe per i trigger e le versioni delle righe vengono archiviate nell'archivio delle versioni in tempdb. Le ottimizzazioni della registrazione bulk sono, pertanto, disponibili anche quando i trigger sono abilitati. Prima di eseguire l'importazione bulk di un batch con un numero elevato di righe con i trigger abilitati, potrebbe essere necessario aumentare le dimensioni di tempdb.

Utilizzo di operazioni di copia bulk basate su file

Il provider OLE DB di SQL Server Native Client implementa l'interfaccia IBCPSession per esporre il supporto per le operazioni di copia bulk SQL Server basate su file. L'interfaccia IBCPSession implementa i metodi IBCPSession::BCPColFmt, IBCPSession::BCPColumns, IBCPSession::BCPControl, IBCPSession::BCPDone, IBCPSession::BCPExec, IBCPSession::BCPInit, IBCPSession::BCPReadFmt e IBCPSession::BCPWriteFmt.

Driver ODBC di SQL Server Native Client

Il driver ODBC di SQL Server Native Client offre lo stesso supporto per le operazioni di copia bulk disponibili nelle versioni precedenti del driver ODBC di SQL Server. Per informazioni sulle operazioni di copia bulk mediante il driver ODBC di SQL Server Native Client, vedere Esecuzione di operazioni di copia bulk (ODBC).