Une sauvegarde complète dans SQL Server 2008 ne rompt pas la chaîne de journaux. Il réinitialise uniquement la base différentielle-lsn.
Vous pouvez également restaurer les sauvegardes de journaux après la restauration à partir d'une copie uniquement. Les démos de script suivantes qui:
CREATE DATABASE BakTst13;
GO
ALTER DATABASE BakTst13 SET RECOVERY FULL;
GO
USE BakTst13;
GO
CREATE TABLE dbo.tst(id INT IDENTITY(1,1));
GO
INSERT INTO dbo.tst DEFAULT VALUES
GO 10
GO
BACKUP DATABASE BakTst13
TO DISK = 'BakTst13_Full_1' WITH INIT,FORMAT;
GO
INSERT INTO dbo.tst DEFAULT VALUES
GO 10
GO
BACKUP LOG BakTst13
TO DISK = 'BakTst13_Log_1' WITH INIT,FORMAT;
GO
INSERT INTO dbo.tst DEFAULT VALUES
GO 10
GO
BACKUP DATABASE BakTst13
TO DISK = 'BakTst13_Full_2' WITH INIT,FORMAT;
GO
INSERT INTO dbo.tst DEFAULT VALUES
GO 10
GO
BACKUP DATABASE BakTst13
TO DISK = 'BakTst13_Full_C' WITH COPY_ONLY,INIT,FORMAT;
GO
INSERT INTO dbo.tst DEFAULT VALUES
GO 10
GO
BACKUP LOG BakTst13
TO DISK = 'BakTst13_Log_2' WITH INIT,FORMAT;
GO
USE tempdb;
GO
DROP DATABASE BakTst13;
GO
RESTORE DATABASE BakTst13 FROM DISK='BakTst13_Full_1' WITH NORECOVERY;
RESTORE LOG BakTst13 FROM DISK='BakTst13_Log_1' WITH NORECOVERY;
RESTORE LOG BakTst13 FROM DISK='BakTst13_Log_2' WITH RECOVERY;
GO
SELECT * FROM BakTst13.dbo.tst;
GO
DROP DATABASE BakTst13;
GO
RESTORE DATABASE BakTst13 FROM DISK='BakTst13_Full_C' WITH NORECOVERY;
RESTORE LOG BakTst13 FROM DISK='BakTst13_Log_2' WITH RECOVERY;
GO
SELECT * FROM BakTst13.dbo.tst;
GO
DROP DATABASE BakTst13;
Il crée une base de données et une table et insère 50 lignes dans cette table. Entre ces insertions, plusieurs sauvegardes sont effectuées dans cet ordre:
- Plein
- Journal
- Plein
- Copie complète_Seulement
- Journal
Ensuite, la base de données est supprimée et restaurée comme ceci:
- 1er plein
- 1er journal
- 2e journal
Ce qui suit SELECT
montre que la restauration a réussi.
Cela montre que ni une COP_ONLY
ni une sauvegarde complète normale ne rompent la chaîne de journaux.
Ensuite, la base de données est à nouveau supprimée et restaurée comme ceci:
- Copy_Only Full
- 2e journal
Ensuite, le SELECT
succès est à nouveau démontré.
Cela montre que vous pouvez utiliser une COPY_ONLY
sauvegarde complète comme base de votre restauration de journal.
Essais différentiels
J'ai aussi créé une DIFFERENTIAL
version:
CREATE DATABASE BakTst13;
GO
ALTER DATABASE BakTst13 SET RECOVERY FULL;
GO
USE BakTst13;
GO
CREATE TABLE dbo.tst(id INT IDENTITY(1,1));
GO
INSERT INTO dbo.tst DEFAULT VALUES
GO 10
GO
BACKUP DATABASE BakTst13
TO DISK = 'BakTst13_Full_1' WITH INIT,FORMAT;
GO
INSERT INTO dbo.tst DEFAULT VALUES
GO 10
GO
BACKUP DATABASE BakTst13
TO DISK = 'BakTst13_Diff_1' WITH DIFFERENTIAL,INIT,FORMAT;
GO
INSERT INTO dbo.tst DEFAULT VALUES
GO 10
GO
BACKUP DATABASE BakTst13
TO DISK = 'BakTst13_Full_2' WITH INIT,FORMAT;
GO
INSERT INTO dbo.tst DEFAULT VALUES
GO 10
GO
BACKUP DATABASE BakTst13
TO DISK = 'BakTst13_Diff_2' WITH DIFFERENTIAL,INIT,FORMAT;
GO
INSERT INTO dbo.tst DEFAULT VALUES
GO 10
GO
BACKUP DATABASE BakTst13
TO DISK = 'BakTst13_Full_C' WITH COPY_ONLY,INIT,FORMAT;
GO
INSERT INTO dbo.tst DEFAULT VALUES
GO 10
GO
BACKUP DATABASE BakTst13
TO DISK = 'BakTst13_Diff_3' WITH DIFFERENTIAL,INIT,FORMAT;
GO
USE tempdb;
GO
DROP DATABASE BakTst13;
GO
RAISERROR('------> Starting restore F1, D1, D2',0,1)WITH NOWAIT;
RESTORE DATABASE BakTst13 FROM DISK='BakTst13_Full_1' WITH NORECOVERY;
RESTORE DATABASE BakTst13 FROM DISK='BakTst13_Diff_1' WITH NORECOVERY;
RESTORE DATABASE BakTst13 FROM DISK='BakTst13_Diff_2' WITH NORECOVERY;--<--Fails!
GO
DROP DATABASE BakTst13;
GO
RAISERROR('------> Starting restore FC, D3',0,1)WITH NOWAIT;
RESTORE DATABASE BakTst13 FROM DISK='BakTst13_Full_C' WITH NORECOVERY;
RESTORE DATABASE BakTst13 FROM DISK='BakTst13_Diff_3' WITH NORECOVERY;--<--Fails!
GO
DROP DATABASE BakTst13;
GO
RAISERROR('------> Starting restore F2, D2, D3',0,1)WITH NOWAIT;
RESTORE DATABASE BakTst13 FROM DISK='BakTst13_Full_2' WITH NORECOVERY;
RESTORE DATABASE BakTst13 FROM DISK='BakTst13_Diff_2' WITH NORECOVERY;
RESTORE DATABASE BakTst13 FROM DISK='BakTst13_Diff_3' WITH RECOVERY;
GO
SELECT * FROM BakTst13.dbo.tst;
GO
DROP DATABASE BakTst13;
Cela prend des sauvegardes dans cet ordre:
- 1er plein
- 1er différentiel
- 2e plein
- 2e différentiel
- Copy_Only Diff
- 3e différentiel
Il essaie ensuite cette route de restauration:
- 1er plein
- 1er différentiel
- 2e différentiel
L'étape 3 échoue avec cette erreur:
Msg 3136, Level 16, State 1, Line 4
This differential backup cannot be restored because the database has not been restored to the correct earlier state.
Cela montre qu'une sauvegarde complète normale rompt la chaîne différentielle.
Ensuite, la base de données est supprimée et ce flux de restauration est tenté:
- Copy_Only Full
- 3e différentiel
L'étape 2 échoue avec la même erreur que l'étape 3 ci-dessus. Cela montre qu'une copie de sauvegarde uniquement ne peut pas être utilisée comme base pour une restauration différentielle.
Ensuite, la base de données est à nouveau supprimée et la restauration suivante est exécutée:
- 2e plein
- 2e différentiel
- 3e différentiel
La sélection suivante prouve que cette restauration a réussi. Cela montre qu'une COPY_ONLY
sauvegarde complète n'interrompt pas la chaîne différentielle.
Voici ce qui se passe lorsque des différentiels sont impliqués:
En un mot: oui, vous pouvez utiliser une
COPY_ONLY
sauvegarde pour restaurer d'autres sauvegardes de journaux. Ce que vous ne pouvez pas faire, c'est utiliser laCOPY_ONLY
sauvegarde comme base différentielle. Cela signifie que vous ne pourrez pas restaurer de sauvegardes différentielles sur laCOPY_ONLY
sauvegarde restaurée :Si vous essayez ceci, vous obtiendrez une erreur:
Les sauvegardes différentielles peuvent être difficiles à comprendre et peuvent tromper même les administrateurs de base de données expérimentés.
la source