Backup di file e filegroup

Si applica a:SQL Server

Questo articolo descrive come eseguire il backup di file e filegroup in SQL Server usando SQL Server Management Studio, Transact-SQL o PowerShell. Quando a causa delle dimensioni del database e dei requisiti relativi alle prestazioni non è consigliabile eseguire un backup completo del database, è possibile creare invece un backup del file. Un backup del file contiene tutti i dati inclusi in uno o più file o filegroup.

Per altre informazioni sul backup dei file, vedere Backup completi del file (SQL Server) e Backup differenziali (SQL Server).

Prima di iniziare

Limitazioni e restrizioni

  • Non è possibile usare l'istruzione BACKUP in una transazione esplicita o implicita .

  • In base al modello di recupero con registrazione minima, è necessario creare una copia di backup contenente tutti i file di lettura/scrittura, al fine di garantire che il database possa essere ripristinato fino a un punto nel tempo coerente. Anziché specificare singolarmente ogni file o filegroup di lettura/scrittura, utilizzare l'opzione READ_WRITE_FILEGROUPS. Questa opzione consente di eseguire il backup di tutti i filegroup di lettura/scrittura del database. Un backup creato con l'opzione READ_WRITE_FILEGROUPS è noto come backup parziale, vedere Backup parziali (SQL Server).

Per altre informazioni sulle limitazioni e restrizioni, vedere Panoramica del backup (SQL Server).

Consigli

Per impostazione predefinita, per ogni operazione di backup eseguita in modo corretto viene aggiunta una voce al log degli errori di SQL Server e al registro eventi di sistema. Se il backup del log viene eseguito di frequente, questi messaggi possono aumentare rapidamente, provocando la creazione di log degli errori di dimensioni elevate e rendendo difficile l'individuazione di altri messaggi. In questo caso è possibile eliminare tali voci di log usando il flag di traccia 3226 se nessuno degli script dipende da esse, vedere Flag di traccia (Transact-SQL).

Autorizzazioni

Le autorizzazioni BACKUP DATABASE e BACKUP LOG vengono assegnate per impostazione predefinita ai membri del ruolo predefinito del server sysadmin e dei ruoli predefiniti del database db_owner e db_backupoperator.

Eventuali problemi correlati alla proprietà e alle autorizzazioni sul file fisico del dispositivo di backup possono interferire con l'operazione di backup. SQL Server deve essere in grado di leggere e scrivere nel dispositivo; l'account con il quale viene eseguito il servizio SQL Server deve avere autorizzazioni di scrittura. Le autorizzazioni di accesso ai file, tuttavia, non vengono controllate dalla stored procedure sp_addumpdeviceche aggiunge una voce per un dispositivo di backup nelle tabelle di sistema. Di conseguenza, i problemi relativi all'accesso e alla proprietà del file fisico del dispositivo di backup potrebbero emergere solo in fase di accesso alla risorsa fisica durante un tentativo di backup o ripristino.

Utilizzo di SQL Server Management Studio

  1. Dopo aver stabilito la connessione all'istanza appropriata del motore di database di SQL Server, in Esplora oggetti fare clic sul nome del server per espanderne l'albero.

  2. Espandere Databasee, a seconda del database, selezionare un database utente o espandere Database di sistema e selezionare un database di sistema.

  3. Fare clic con il pulsante destro del mouse sul database, scegliere Attivitàe quindi fare clic su Backup. Verrà visualizzata la finestra di dialogo Backup database .

  4. Verificare il nome del database nell'elenco Database . È possibile selezionare facoltativamente un database diverso nell'elenco.

  5. Nell'elenco Tipo di backup selezionare Completo o Differenziale.

  6. Selezionare l'opzione File e filegroup in Componente di cui eseguire il backup.

  7. Selezionare i file e i filegroup dei quali si desidera eseguire il backup nella finestra di dialogo Seleziona file e filegroup . È possibile selezionare uno o più file singoli oppure selezionare la casella di controllo relativa a un filegroup per selezionare automaticamente tutti i file appartenenti al filegroup.

  8. Accettare il nome predefinito del set di backup indicato nella casella di testo Nome oppure immettere un nome diverso per il set di backup.

  9. Immettere una descrizione del set di backup nella casella di testo Descrizione (facoltativo).

  10. Specificare la scadenza del set di backup:

    • Per impostare la scadenza del set di backup dopo un numero di giorni specifico, fare clic su Dopo (opzione predefinita) e immettere il numero di giorni dopo la creazione del set trascorsi i quali il set scadrà. È possibile impostare un valore compreso nell'intervallo da 0 a 99999 giorni. L'impostazione del valore 0 giorni indica che il set di backup non ha scadenza.

      Il valore predefinito viene impostato nell'opzione Periodo di memorizzazione predefinito supporti di backup (giorni) della finestra di dialogo Proprietà server (paginaImpostazioni database ). Per accedere a questa opzione, fare clic con il pulsante destro del mouse sul nome del server in Esplora oggetti, scegliere Proprietà e quindi selezionare la pagina Impostazioni database .

    • Per impostare una data di scadenza specifica per il set di backup, fare clic su Ile immettere la data di scadenza del set.

  11. Fare clic su Disco o su Nastroper selezionare il tipo di destinazione del backup. Per selezionare i percorsi per un massimo di 64 unità disco o nastro contenenti un singolo set di supporti, fare clic su Aggiungi. I percorsi selezionati vengono visualizzati nell'elenco Backup su .

    Nota

    Per rimuovere una destinazione di backup, selezionarla e fare clic su Rimuovi. Per visualizzare il contenuto di una destinazione di backup, selezionarla e fare clic su Contenuto.

  12. Per visualizzare o selezionare le opzioni avanzate, fare clic su Opzioni nel riquadro Selezione pagina .

  13. Selezionare un'opzione Sovrascrivi supporti facendo clic su una delle opzioni seguenti:

    • Esegui backup nel set di supporti esistente

      Per questa opzione, fare clic su Accoda al set di backup esistente o Sovrascrivi tutti i set di backup esistenti.

      Per informazioni sul backup in un set di supporti esistente, vedere Set di supporti, gruppi di supporti e set di backup (SQL Server).

      • Selezionare l'opzione Controlla nome set di supporti e scadenza set di backup per impostare la verifica della data e dell'ora di scadenza del set di supporti e del set di backup durante l'operazione di backup (facoltativo).

      • Immettere un nome nella casella di testo Nome set di supporti (facoltativo). Se non si specifica un nome, verrà creato un set di supporti con nome vuoto. Se si specifica il nome di un set di supporti, viene eseguito un controllo sul supporto (nastro o disco) per verificare che il nome effettivo corrisponda al nome qui immesso.

      Se non si specifica il nome del set di supporti e si seleziona la casella di controllo per il controllo del nome, in caso di esito positivo anche il nome dei supporti nei supporti risulterà vuoto.

    • Esegui backup in un nuovo set di supporti e cancella tutti i set di backup esistenti

      Per questa opzione, immettere un nome nella casella di testo Nome nuovo set di supporti e, facoltativamente, aggiungere una descrizione per il set di supporti nella casella di testo Descrizione nuovo set di supporti .

      Per altre informazioni sulla creazione di un nuovo set di supporti, vedere Set di supporti, gruppi di supporti e set di backup (SQL Server).

  14. Nella sezione Affidabilità selezionare (facoltativo):

  15. Se si esegue il backup su un'unità nastro, come specificato nella sezione Destinazione della pagina Generale , l'opzione Scarica nastro al termine del backup sarà attiva. Selezionando questa opzione viene abilitata anche l'opzione Riavvolgi il nastro prima di scaricarlo .

    Nota

    Le opzioni presenti nella sezione Log delle transazioni sono attive solo in caso di backup di un log delle transazioni, come specificato nella sezione Tipo backup nella pagina Generale .

  16. SQL Server 2008 (10.0.x) Enterprise e versioni successive supportano la compressione dei backup. Per impostazione predefinita, la compressione di un backup dipende dal valore dell'opzione di configurazione del server Valore predefinito di compressione backup. Tuttavia, indipendentemente dall'impostazione predefinita a livello di server corrente, è possibile comprimere un backup selezionando Comprimi backuped è possibile impedire la compressione selezionando Non comprimere il backup.

    Per visualizzare l'impostazione predefinita di compressione dei backup, vedere Visualizzare o configurare l'opzione di configurazione del server backup compression default

Utilizzo di Transact-SQL

Per creare un backup del file o del filegroup, usare un'istruzione BACKUP DATABASE < >. In questa istruzione è necessario specificare almeno gli elementi seguenti:

  • Nome del database.

  • Una clausola FILE o FILEGROUP per ogni file o filegroup, rispettivamente.

  • Il dispositivo di backup in cui verrà scritto il backup completo.

La sintassi Transact-SQL di base per un backup del file è la seguente:

BACKUP DATABASE database

{ FILE =nome_file_logico | FILEGROUP =nome_filegroup_logico } [ ,...f ]

TO dispositivo_backup [ ,...n ]

[ WITH con_opzioni [ ,...o ] ];

Opzione Descrizione
database Nome del database di cui viene eseguito il backup del log delle transazioni oppure il backup parziale o completo del database.
FILE =nome_file_logico Specifica il nome logico di un file da includere nel backup del file.
FILEGROUP =nome_filegroup_logico Specifica il nome logico di un filegroup da includere nel backup del file. Con il modello di recupero con registrazione minima, il backup dei filegroup è consentito solo per i filegroup di sola lettura.
[ ,...f ] Segnaposto che indica che è possibile specificare più file e filegroup. Il numero di file o filegroup che possono essere specificati è illimitato.
backup_device [ ,...n ] Specifica un elenco di dispositivi di backup da 1 a 64 da utilizzare per l'operazione di backup. È possibile specificare un dispositivo di backup fisico oppure un dispositivo di backup logico corrispondente se è già stata definito. Per specificare un dispositivo di backup fisico, utilizzare l'opzione DISK o TAPE:

{ DISK | TAPE } =physical_backup_device_name

Per altre informazioni, vedere Dispositivi di backup (SQL Server).
WITH con_opzioni [ ,...o ] Facoltativamente, specifica una o più opzioni aggiuntive, ad esempio DIFFERENTIAL. un backup differenziale del file richiede come base un backup completo del file.

Per altre informazioni, vedere Creare un backup differenziale del database (SQL Server).

Se si utilizza il modello di recupero con registrazione completa, è inoltre necessario eseguire un backup del log delle transazioni. Per utilizzare un set completo di backup del file completi per il ripristino di un database, è inoltre necessario disporre di backup dei log relativi a tutti i backup del file, dall'inizio del primo backup del file.

Per altre informazioni, vedere Backup di un log delle transazioni (SQL Server).

Esempi

Negli esempi seguenti viene eseguito il backup di uno o più file dei filegroup secondari del database Sales . Questo database utilizza il modello di recupero con registrazione completa e contiene i filegroup secondari seguenti:

  • Un filegroup denominato SalesGroup1 che include i file SGrp1Fi1 e SGrp1Fi2.

  • Un filegroup denominato SalesGroup2 che include i file SGrp2Fi1 e SGrp2Fi2.

R. Creare un backup di due file

Nell'esempio seguente viene creato un backup differenziale del file solo per il file SGrp1Fi2 del filegroup SalesGroup1 e per il file SGrp2Fi2 del filegroup SalesGroup2 .

--Backup the files in the SalesGroup1 secondary filegroup.  
BACKUP DATABASE Sales  
   FILE = 'SGrp1Fi2',   
   FILE = 'SGrp2Fi2'   
   TO DISK = 'G:\SQL Server Backups\Sales\SalesGroup1.bck';  
GO  

B. Creare un backup completo dei filegroup secondari

Nell'esempio seguente viene creato un backup completo di ogni file presente in entrambi i filegroup secondari.

--Back up the files in SalesGroup1.  
BACKUP DATABASE Sales  
   FILEGROUP = 'SalesGroup1',  
   FILEGROUP = 'SalesGroup2'  
   TO DISK = 'C:\MySQLServer\Backups\Sales\SalesFiles.bck';  
GO  

C. Creare un backup differenziale dei filegroup secondari

Nell'esempio seguente viene creato un backup differenziale di ogni file presente in entrambi i filegroup secondari.

--Back up the files in SalesGroup1.  
BACKUP DATABASE Sales  
   FILEGROUP = 'SalesGroup1',  
   FILEGROUP = 'SalesGroup2'  
   TO DISK = 'C:\MySQLServer\Backups\Sales\SalesFiles.bck'  
   WITH   
      DIFFERENTIAL;  
GO  

Utilizzo di PowerShell

Impostare e usare il provider SQL Server PowerShell.

Usare il cmdlet Backup-SqlDatabase e specificare Files per il valore del parametro -BackupAction . Inoltre, specificare uno dei parametri seguenti:

  • Per eseguire il backup di un determinato file, specificare il parametro -DatabaseFileString , dove String rappresenta uno o più file di database di cui eseguire il backup.

  • Per eseguire il backup di tutti i file di un determinato filegroup, specificare il parametro -DatabaseFileGroupString , dove String rappresenta uno o più filegroup di database di cui eseguire il backup.

Nell'esempio seguente viene creato un backup completo di ogni file presente nei filegroup secondari 'FileGroup1' e 'FileGroup2' nel database <myDatabase> . I backup vengono creati nel percorso di backup predefinito dell'istanza del server Computer\Instance.

Backup-SqlDatabase -ServerInstance Computer\Instance -Database <myDatabase> -BackupAction Files -DatabaseFileGroup "FileGroup1","FileGroup2" 

Vedi anche

Panoramica del backup (SQL Server)
BACKUP (Transact-SQL)
RESTORE (Transact-SQL)
Informazioni sulla cronologia e sull'intestazione del backup (SQL Server)
Backup database (pagina Generale)
Backup database (pagina Opzioni di backup)
Backup completi dei file (SQL Server)
Backup differenziali (SQL Server)
Ripristini di file (modello di recupero con registrazione completa)
Ripristini di file (modello di recupero con registrazione minima)