Share via


RESTORE Arguments (Transact-SQL)

This topic documents the arguments that are described in the Syntax sections of the RESTORE {DATABASE|LOG} statement and of the associated set of auxiliary statements: RESTORE FILELISTONLY, RESTORE HEADERONLY, RESTORE LABELONLY, RESTORE REWINDONLY, and RESTORE VERIFYONLY. Most of the arguments are supported by only a subset of these six statements. The support for each argument is indicated in the description of the argument.

Topic link iconTransact-SQL Syntax Conventions

Syntax

For syntax, see the following topics:

Arguments

  • DATABASE

    Note

    Supported by RESTORE.

    Specifies the target database. If a list of files and filegroups is specified, only those files and filegroups are restored.

    For a database using the full or bulk-logged recovery model, Microsoft SQL Server 2005 requires in most cases that you back up the tail of the log before restoring the database. Restoring a database without first backing up the tail of the log results in an error, unless the RESTORE statement contains either the WITH REPLACE or WITH STOPAT clause. For more information about tail-log backups, see Tail-Log Backups.

  • LOG

    Note

    Supported by RESTORE.

    Specifies that a transaction log backup is to be applied to this database. Transaction logs must be applied in sequential order. SQL Server checks the backed up transaction log to ensure that the transactions are being loaded into the correct database and in the correct sequence. To apply multiple transaction logs, use the NORECOVERY option on all restore operations except the last.

    Note

    Typically, the last log restored is the tail-log backup. A tail-log backup is a log backup taken right before restoring a database, typically after a failure on the database. Taking a tail-log backup from the possibly damaged database prevents work loss by capturing the log that has not yet been backed up (the tail of the log). For more information, see Tail-Log Backups.

    For more information, see Working with Transaction Log Backups.

  • { database_name | **@**database_name_var}

    Note

    Supported by RESTORE.

    Is the database that the log or complete database is restored into. If supplied as a variable (**@database_name_var), this name can be specified either as a string constant (@**database_name_var = database_name) or as a variable of character string data type, except for the ntext or text data types.

  • <file_or_filegroup_or_page> [ ,...n ]

    Note

    Supported by RESTORE.

    Specifies the name of a logical file or filegroup or page to include in a RESTORE DATABASE or RESTORE LOG statement. You can specify a list of files or filegroups.

    For a database that uses the simple recovery model, the FILE and FILEGROUP options are allowed only if the target files or filegroups are read only, or if this is a PARTIAL restore (which results in a defunct filegroup).

    For a database that uses the full or bulk-logged recovery model, after using RESTORE DATABASE to restore one or more files, filegroups, and/or pages, typically, you must apply the transaction log to the files containing the restored data; applying the log makes those files consistent with the rest of the database. The exceptions to this are as follows:

    • If the files being restored were read-only before they were last backed up—then a transaction log does not have to be applied, and the RESTORE statement informs you of this situation
    • If the backup contains the primary filegroup and a partial restore is being performed. In this case, the restore log is not needed because the log is restored automatically from the backup set.
    • FILE = { logical_file_name_in_backup| **@**logical_file_name_in_backup_var}
      Names a file to include in the database restore.
    • FILEGROUP = { logical_filegroup_name | **@**logical_filegroup_name_var }
      Names a filegroup to include in the database restore.

      Note   FILEGROUP is allowed in simple recovery model only if the specified filegroup is read-only and this is a partial restore (that is, if WITH PARTIAL is used). Any unrestored read-write filegroups are marked as defunct and cannot subsequently be restored into the resulting database.

    • READ_WRITE_FILEGROUPS
      Selects all read-write filegroups. This option is particularly useful when you have read-only filegroups that you want to restore after read-write filegroups before the read-only filegroups.
    • PAGE = 'file:page [ ,...n ]'
      Specifies a list of one or more pages for a page restore (which is supported only for databases using the full or bulk-logged recovery models). The values are as follows:

      • PAGE
        Indicates a list of one or more files and pages.
      • file
        Is the file ID of the file containing a specific page to be restored.
      • page
        Is the page ID of the page to be restored in the file.
      • n
        Is a placeholder indicating that multiple pages can be specified.

        The maximum number of pages that can be restored into any single file in a restore sequence is 1000. However, if you have more than a small number of damaged pages in a file, consider restoring the whole file instead of the pages.

      For more information about page restore, see Performing Page Restores.

    • [ ,...n ]
      Is a placeholder indicating that multiple files and filegroups and pages can be specified in a comma-separated list. The number is unlimited.
  • FROM { <backup_device> [ ,...n ] | <database_snapshot> }
    Typically, specifies the backup devices from which to restore the backup. Alternatively, in a RESTORE DATABASE statement, the FROM clause can specify the name of a database snapshot to which you are reverting the database, in which case, no WITH clause is permitted.

    If the FROM clause is omitted, the restore of a backup does not take place. Instead, the database is recovered. This allows you to recover a database that has been restored with the NORECOVERY option or to switch over to a standby server. If the FROM clause is omitted, NORECOVERY, RECOVERY, or STANDBY must be specified in the WITH clause.

    • <backup_device> [ ,...n ]
      Specifies the logical or physical backup devices to use for the restore operation.

      • <backup_device>::=
        Specifies a logical or physical backup device to use for the backup operation, as follows:

        • { logical_backup_device_name | **@logical_backup_device_name_var }
          Is the logical name, which must follow the rules for identifiers, of the backup device(s) created by sp_addumpdevice from which the database is restored. If supplied as a variable (
          @logical_backup_device_name_var), the backup device name can be specified either as a string constant (@**logical_backup_device_name_var = logical_backup_device_name) or as a variable of character string data type, except for the ntext or text data types.
        • {DISK | TAPE } = { 'physical_backup_device_name' | **@physical_backup_device_name_var }
          Allows backups to be restored from the named disk or tape device. The device types of disk and tape should be specified with the actual name (for example, complete path and file name) of the device: DISK = 'C:\Program Files\Microsoft SQL Server\MSSQL\BACKUP\Mybackup.bak' or TAPE = '\\.\TAPE0'. If specified as a variable (
          @physical_backup_device_name_var), the device name can be specified either as a string constant (@**physical_backup_device_name_var = 'physcial_backup_device_name') or as a variable of character string data type, except for the ntext or text data types.

          If using a network server with a UNC name (which must contain machine name), specify a device type of disk. For more information about how to use UNC names, see Backup Devices.

          The account under which you are running SQL Server must have READ access to the remote computer or network server in order to perform a RESTORE operation.

      • n
        Is a placeholder indicating that up to 64 backup devices may be specified in a comma-separated list.

        Whether a restore sequence requires as many backup devices as were used to create the media set to which the backups belong, depends on whether the restore is offline or online, as follows:

        • Offline restore allows a backup to be restored using fewer devices than were used to create the backup.
        • Online restore requires all the backup devices of the backup. An attempt to restore with fewer devices fails.

        For example, consider a case in which a database was backed up to four tape drives connected to the server. An online restore requires that you have four drives connected to the server; an offline restore allows you to restore the backup if there are less than four drives on the machine.

        For more information, see Working with Backup Media in SQL Server.

      Note

      When you are restoring a backup from a mirrored media set, you can specify only a single mirror for each media family. In the presence of errors, however, having the other mirrors enables some restore problems to be resolved quickly. You can substitute a damaged media volume with the corresponding volume from another mirror. Be aware that for offline restores you can restore from fewer devices than media families, but each family is processed only once.

    • <database_snapshot>::=

      Note

      Supported by RESTORE {DATABASE}.

      • DATABASE_SNAPSHOT **=**database_snapshot_name
        Reverts the database to the database snapshot specified by database_snapshot_name. The DATABASE_SNAPSHOT option is available only for a full database restore. In a revert operation, the database snapshot takes the place of a full database backup.

        A revert operation requires that the specified database snapshot is the only one on the database. During the revert operation, the database snapshot and the destination database and are both marked as In restore. For more information, see the "Remarks" section in RESTORE {DATABASE}.

WITH <with_options> ::=

Specifies the options to be used by a restore operation. For a summary of which statements use each option, see "Summary of Support for WITH Options," later in this topic.

  • PARTIAL

    Note

    Supported only by RESTORE {DATABASE}.

    Specifies a partial restore operation that restores the primary filegroup and any specified secondary filegroup(s). The PARTIAL option implicitly selects the primary filegroup; specifying FILEGROUP = 'PRIMARY' is unnecessary. To restore a secondary filegroup, you must explicitly specify the filegroup using the FILE option or FILEGROUP option.

    The PARTIAL option is not allowed on RESTORE LOG statements.

    Beginning with SQL Server 2005, the PARTIAL option starts the initial stage of a piecemeal restore, which allows remaining filegroups to be restored at a later time. For more information, see Performing Piecemeal Restores.

    Note

    The initial stage of a piecemeal restore, replaces the Microsoft SQL Server 2000 partial database restore. A partial database restore was designed to restore only a damaged part of a database (a subset of filegroups) into a new location so that the damaged or missing data can be copied back to the original database. A partially restored database was not intended to be used as a production database, and to improve performance, RESTORE ignored many of the normal safety checks. However, n SQL Server 2005, the PARTIAL option performs those safety checks.

  • { CHECKSUM | NO_CHECKSUM }

    The default behavior is to verify checksums if they are present and proceed without verification if they are not present.

    • CHECKSUM
      Specifies that backup checksums must be verified and, if the backup lacks backup checksums, causes the restore operation to fail with a message indicating that checksums are not present.

      By default, on encountering an invalid checksum, RESTORE reports a checksum error and stops. However, if you specify CONTINUE_AFTER_ERROR, RESTORE proceeds after returning a checksum error and the number of the page containing the invalid checksum, if the corruption permits.

      Backup checksums are new in SQL Server 2005. For more information about working with backup checksums, see Detecting and Coping with Media Errors.

    • NO_CHECKSUM
      Explicitly disables the validation of checksums by the restore operation.
  • { STOP_ON_ERROR | CONTINUE_AFTER_ERROR }

    • STOP_ON_ERROR
      Specifies that the restore operation stops with the first error encountered. This is the default behavior for RESTORE, except for VERIFYONLY which has CONTINUE_AFTER_ERROR as the default.
    • CONTINUE_AFTER_ERROR
      Specifies that the restore operation is to continue after an error is encountered.

      For information about continuing despite errors, see Responding to SQL Server Restore Errors Caused by Damaged Backups.

      If a backup contains damaged pages, it is best to repeat the restore operation using an alternate backup that does not contain the errors—for example, a backup taken before the pages were damaged. As a last resort, however, you can restore a damaged backup using the CONTINUE_AFTER_ERROR option of the restore statement and attempt to salvage the data.

  • FILE ={ backup_set_file_number | **@**backup_set_file_number }

    Identifies the backup set to be restored. For example, a backup_set_file_number of 1 indicates the first backup set on the backup medium and a backup_set_file_number of 2 indicates the second backup set.

    When not specified, the default is 1, except for RESTORE HEADERONLY in which case all backup sets in the media set are processed. For more information, see "Specifying a Backup Set," later in this topic.

    Important

    This FILE option is unrelated to the FILE option for specifying a database file, FILE = { logical_file_name_in_backup | @logical_file_name_in_backup_var }.

  • KEEP_REPLICATION

    Note

    Supported only by RESTORE.

    KEEP_REPLICATION should used when setting up replication to work with log shipping. It prevents replication settings from being removed when a database backup or log backup is restored on a warm standby server and the database is recovered. Specifying this option when restoring a backup with the NORECOVERY option is not permitted. To ensure replication functions properly after restore:

    • The msdb and master databases at the warm standby server must be in sync with the msdb and master databases at the primary server.
    • The warm standby server must be renamed to use the same name as the primary server.
  • LOADHISTORY

    Note

    Supported by RESTORE VERIFYONLY.

    Specifies that the restore operation loads the information into the msdb history tables. The LOADHISTORY option loads information, for the single backup set being verified, about SQL Server backups stored on the media set to the backup and restore history tables in the msdb database. For more information about history tables, see System Tables (Transact-SQL).

  • MEDIANAME = { media_name | **@**media_name_variable}

    Specifies the name for the media. If provided, the media name must match the media name on the backup volumes; otherwise, the restore operation terminates. If no media name is given in the RESTORE statement, the check for a matching media name on the backup volumes is not performed.

    Important

    Consistently using media names in backup and restore operations provides an extra safety check for the media selected for the restore operation.

  • MEDIAPASSWORD = { mediapassword | **@**mediapassword_variable }

    Supplies the password of the media set. A media-set password is a character string.

    If a password was provided when the media set was formatted, that password is required to access any backup set on the media set. It is an error to specify the wrong password or to specify a password if the media set does not have any.

    Important

    This password provides only weak protection for the media set. For more information, see the "Permissions" section for the relevant statement.

    Note

    The MEDIAPASSWORD option will be removed in a future release.

  • MOVE 'logical_file_name_in_backup' TO 'operating_system_file_name' [ ...*n *]

    Note

    Supported by RESTORE and RESTORE VERIFYONLY.

    Specifies that the data or log file whose logical name is specified by logical_file_name_in_backup should be moved by restoring it to the location specified by operating_system_file_name. The logical file name of a data or log file in a backup set matches its logical name in the database when the backup set was created.

    n is a placeholder indicating that you can specify additional MOVE statements. Specify a MOVE statement for every logical file you want to restore from the backup set to a new location. By default, the logical_file_name_in_backup file is restored to its original location.

    Note

    To obtain a list of the logical files from the backup set, use RESTORE FILELISTONLY.

    If a RESTORE statement is used to relocate a database on the same server or copy it to a different server, the MOVE option might be necessary to relocate the database files and to avoid collisions with existing files.

    When used with RESTORE LOG, the MOVE option can be used only to relocate files that were added during the interval covered by the log being restored. For example, if the log backup contains an add file operation for file file23, this file may be relocated using the MOVE option on RESTORE LOG.

    If a RESTORE VERIFYONLY statement is used when you plan to relocate a database on the same server or copy it to a different server, the MOVE option might be necessary to verify that sufficient space is available in the target and to identify potential collisions with existing files.

    For more information, see Copying Databases with Backup and Restore.

  • PASSWORD = { password | **@**password_variable }

    Supplies the password of the backup set. A backup-set password is a character string.

    If a password was specified when the backup set was created, that password is required to perform any restore operation from the backup set. It is an error to specify the wrong password or to specify a password if the backup set does not have one.

    Important

    This password provides only weak protection for the media set. For more information, see the Permissions section for the relevant statement.

    Note

    The PASSWORD option will be removed in a future release of SQL Server.

  • BLOCKSIZE = { blocksize | **@**blocksize_variable }
    Specifies the physical block size, in bytes. The supported sizes are 512, 1024, 2048, 4096, 8192, 16384, 32768, and 65536 (64 KB) bytes. The default is 65536 for tape devices and 512 otherwise. Typically, this option is unnecessary because RESTORE automatically selects a block size that is appropriate to the device. Explicitly stating a block size overrides the automatic selection of block size.

    If you are restoring a backup from a CD-ROM, specify BLOCKSIZE=2048.

    Note

    This option typically affects performance only when reading from tape devices.

  • BUFFERCOUNT = { buffercount | **@**buffercount_variable }
    Specifies the total number of I/O buffers to be used for the restore operation. You can specify any positive integer; however, large numbers of buffers might cause "out of memory" errors because of inadequate virtual address space in the Sqlservr.exe process.

    The total space used by the buffers is determined by: buffercount*****maxtransfersize.

  • MAXTRANSFERSIZE = { maxtransfersize | **@**maxtransfersize_variable }
    Specifies the largest unit of transfer in bytes to be used between the backup media and SQL Server. The possible values are multiples of 65536 bytes (64 KB) ranging up to 4194304 bytes (4 MB).
  • ENABLE_BROKER

    Note

    Supported only by RESTORE {DATABASE}.

    Starts Service Broker in enabled mode so that messages can be sent immediately. By default Service Broker starts in disabled mode during a restore.

  • ERROR_BROKER_CONVERSATIONS

    Note

    Supported only by RESTORE {DATABASE}.

    Ends all conversations with an error stating that the database is attached or restored. The broker is disabled until this operation is completed and then enabled.

  • NEW_BROKER

    Note

    Supported only by RESTORE {DATABASE}.

    Creates a new service_broker_guid value in both sys.databases and the restored database and ends all conversation endpoints with clean up. The broker is enabled, but no message is sent to the remote conversation endpoints.

  • { RECOVERY | NORECOVERY | STANDBY }

    Note

    Supported only by RESTORE.

    • RECOVERY
      Instructs the restore operation to roll back any uncommitted transactions. After the recovery process, the database is ready for use. If neither NORECOVERY, RECOVERY, nor STANDBY is specified, RECOVERY is the default.

      If subsequent RESTORE operations (RESTORE LOG, or RESTORE DATABASE from differential) are planned, NORECOVERY or STANDBY should be specified instead.

      When restoring backup sets from an earlier version of SQL Server, a database upgrade might be required. This upgrade is performed automatically when WITH RECOVERY is specified. For more information, see Applying Transaction Log Backups.

      Note

      If the FROM clause is omitted, NORECOVERY, RECOVERY, or STANDBY must be specified in the WITH clause.

    • NORECOVERY
      Instructs the restore operation to not roll back any uncommitted transactions. If another transaction log has to be applied later, specify either the NORECOVERY or STANDBY option. If neither NORECOVERY, RECOVERY, nor STANDBY is specified, RECOVERY is the default. During an offline restore operation using the NORECOVERY option, the database is not usable.

      For restoring a database backup and one or more transaction logs or whenever multiple RESTORE statements are necessary (for example, when restoring a full database backup followed by a differential database backup), RESTORE requires the WITH NORECOVERY option on all but the final RESTORE statement. A best practice is to use WITH NORECOVERY on ALL statements in a multi-step restore sequence until the desired recovery point is reached, and then to use a separate RESTORE WITH RECOVERY statement for recovery only.

      When used with a file or filegroup restore operation, NORECOVERY forces the database to remain in the restoring state after the restore operation. This is useful in either of these situations:

      • A restore script is being run and the log is always being applied.
      • A sequence of file restores is used and the database is not intended to be usable between two of the restore operations.

      In some cases RESTORE WITH NORECOVERY rolls the roll forward set far enough forward that it is consistent with the database. In such cases, roll back does not occur and the data remains offline, as expected with this option. However, the Database Engine issues an informational message that states that the roll-forward set can now be recovered by using the RECOVERY option.

    • STANDBY **=**standby_file_name
      Specifies a standby file that allows the recovery effects to be undone. The STANDBY option is allowed for offline restore (including partial restore). The option is disallowed for online restore. Attempting to specify the STANDBY option for an online restore operation causes the restore operation to fail. STANDBY is also not allowed when a database upgrade is necessary.

      Note

      In SQL Server 2000, this file was known as the "undo file."

      The standby file is used to keep a "copy-on-write" pre-image for pages modified during the undo pass of a RESTORE WITH STANDBY. The standby file allows a database to be brought up for read-only access between transaction log restores and can be used with either warm standby server situations or special recovery situations in which it is useful to inspect the database between log restores. After a RESTORE WITH STANDBY operation, the undo file is automatically deleted by the next RESTORE operation. If this standby file is manually deleted before the next RESTORE operation, then the entire database must be re-restored. While the database is in the STANDBY state, you should treat this standby file with the same care as any other database file. Unlike other database files, this file is only kept open by the Database Engine during active restore operations.

      The standby_file_name specifies a standby file whose location is stored in the log of the database. If an existing file is using the specified name, the file is overwritten; otherwise, the Database Engine creates the file.

      The size requirement of a given standby file depends on the volume of undo actions resulting from uncommitted transactions during the restore operation.

      Important

      If free disk space is exhausted on the drive containing the specified standby file name, the restore operation stops.

    For a comparison of RECOVERY and NORECOVERY, see the "Remarks" section in RESTORE.

  • REPLACE

    Note

    Supported only by RESTORE.

    Specifies that SQL Server should create the specified database and its related files even if another database already exists with the same name. In such a case, the existing database is deleted. When the REPLACE option is not specified, a safety check occurs. This prevents overwriting a different database by accident. The safety check ensures that the RESTORE DATABASE statement does not restore the database to the current server if the following conditions both exist:

    • The database named in the RESTORE statement already exists on the current server, and
    • The database name is different from the database name recorded in the backup set.

    REPLACE also allows RESTORE to overwrite an existing file that cannot be verified as belonging to the database being restored. Normally, RESTORE refuses to overwrite pre-existing files. WITH REPLACE can also be used in the same way for the RESTORE LOG option.

    REPLACE also overrides the requirement that you back up the tail of the log before restoring the database.

    For more information, see Using the REPLACE Option.

  • RESTART

    Note

    Supported only by RESTORE.

    Specifies that SQL Server should restart a restore operation that has been interrupted. RESTART restarts the restore operation at the point it was interrupted.

  • RESTRICTED_USER

    Note

    Supported only by RESTORE.

    Restricts access for the newly restored database to members of the db_owner, dbcreator, or sysadmin roles. In SQL Server 2005, RESTRICTED_USER replaces the DBO_ONLY option. DBO_ONLY is available only for backward compatibility.

    Use with the RECOVERY option.

    For more information, see Setting Database Options.

  • { REWIND | NOREWIND }
    These options are used only for TAPE devices. If a non-tape device is being used, these options are ignored.

    • NOREWIND

      Note

      Supported only by RESTORE and RESTORE VERIFYONLY. Specifying NOREWIND in any other restore statement generates an error.

      Specifies that SQL Server will keep the tape open after the backup operation. You can use this option to improve performance when performing multiple backup operations to a tape.

      NOREWIND implies NOUNLOAD, and these options are incompatible within a single RESTORE statement.

      Note

      If you use NOREWIND, the instance of SQL Server retains ownership of the tape drive until a BACKUP or RESTORE statement running in the same process uses either the REWIND or UNLOAD option, or the server instance is shut down. Keeping the tape open prevents other processes from accessing the tape. For information about how to display a list of open tapes and to close an open tape, see Backup Devices.

  • { UNLOAD | NOUNLOAD }

    These options are used only for TAPE devices. If a non-tape device is being used, these options are ignored.

    Note

    UNLOAD/NOUNLOAD is a session setting that persists for the life of the session or until it is reset by specifying the alternative.

    • UNLOAD
      Specifies that the tape is automatically rewound and unloaded when the backup is finished. UNLOAD is the default when a session begins.
    • NOUNLOAD
      Specifies that after the RESTORE operation the tape will remain loaded on the tape drive.
  • STATS [ = percentage ]

    Note

    Supported by RESTORE and RESTORE VERIFYONLY.

    Displays a message each time another percentage completes, and is used to gauge progress. If percentage is omitted, SQL Server displays a message after each 10 percent is completed (approximately).

    The STATS option reports the percentage complete as of the threshold for reporting the next interval. This is at approximately the specified percentage; for example, with STATS=10, the Database Engine reports at approximately that interval; for instance, instead of displaying precisely 40%, the option might display 43%. For large backup sets, this is not a problem because the percentage complete moves very slowly between completed I/O calls.

  • { STOPAT | STOPATMARK | STOPBEFOREMARK }

    Note

    Supported only by RESTORE and only for the full or bulk-logged recovery models.

    • STOPAT = { 'date_time' | **@**date_time_var }
      Specifies that the database be restored to the state it was in as of the specified date and time.

      If a variable is used for STOPAT, the variable must be varchar, char, smalldatetime, or datetime data type. Only transaction log records written before the specified date and time are applied to the database.

      Note

      If the specified STOPAT time is after the last LOG backup, the database is left in the unrecovered state, just as if RESTORE LOG ran with NORECOVERY.

      For more information, see Restoring a Database to a Point Within a Backup.

    • STOPATMARK = { 'mark_name' | 'lsn:lsn_number' } [ AFTER 'datetime' ]
      Specifies recovery to a specified recovery point. The specified transaction is included in the recovery, but it is committed only if it was originally committed when the transaction was actually generated.

      Both RESTORE DATABASE and RESTORE LOG support the lsn_number parameter. This parameter specifies a log sequence number.

      The mark_name parameter is supported only by the RESTORE LOG statement. This parameter identifies a transaction mark in the log backup.

      In a RESTORE LOG statement, if AFTER datetime is omitted, recovery stops at the first mark with the specified name. If AFTER datetime is specified, recovery stops at the first mark having the specified name exactly at or after datetime.

      Note

      If the specified mark, LSN, or time is after the last LOG backup, the database is left in the unrecovered state, just as if RESTORE LOG ran with NORECOVERY.

      For more information, see Using Marked Transactions (Full Recovery Model) and Recovering to a Log Sequence Number (LSN).

    • STOPBEFOREMARK = { 'mark_name' | 'lsn:lsn_number' } [ AFTER 'datetime' ]
      Specifies recovery up to a specified recovery point. The specified transaction is not included in the recovery, and is rolled back when WITH RECOVERY is used.

      Both RESTORE DATABASE and RESTORE LOG support the lsn_number parameter. This parameter specifies a log sequence number.

      The mark_name parameter is supported only by the RESTORE LOG statement. This parameter identifies a transaction mark in the log backup.

      In a RESTORE LOG statement, if AFTER datetime is omitted, recovery stops just before the first mark with the specified name. If AFTER datetime is specified, recovery stops just before the first mark having the specified name exactly at or after datetime.

Result Sets

For result sets, see the following topics:

Remarks

For additional remarks, see the following topics:

Specifying a Backup Set

A backup set contains the backup from a single, successful backup operation. RESTORE, RESTORE FILELISTONLY, RESTORE HEADERONLY, and RESTORE VERIFYONLY statements operate on a single backup set within the media set on the specified backup device or devices. You should specify the backup you need from within the media set.

The option for specifying the backup set to restore is:

FILE ={ backup_set_file_number | **@**backup_set_file_number }

Where backup_set_file_number indicates the position of the backup in the media set. A backup_set_file_number of 1 (FILE = 1) indicates the first backup set on the backup medium and a backup_set_file_number of 2 (FILE = 2) indicates the second backup set, and so on.

The behavior of this option varies depending on the statement, as described in the following table.

Statement

Behavior of backup-set FILE option

RESTORE

The default backup set file number is 1. Only one backup-set FILE option is allowed in a RESTORE statement. It is important to specify backup sets in order.

RESTORE FILELISTONLY

The default backup set file number is 1.

RESTORE HEADERONLY

By default, all backup sets in the media set are processed. The RESTORE HEADERONLY results set returns information about each backup set, including its Position in the media set. To return information on a given backup set, use its position number as the backup_set_file_number value in the FILE option.

ms178615.note(en-US,SQL.90).gifNote:

For tape media, RESTORE HEADER only processes backup sets on the loaded tape.

RESTORE VERIFYONLY

The default backup_set_file_number is 1.

Note

The FILE option for specifying a backup set is unrelated to the FILE option for specifying a database file, FILE = { logical_file_name_in_backup | @logical_file_name_in_backup_var }.

Summary of Support for WITH Options

The following WITH options are supported by only the RESTORE statement: PARTIAL, KEEP_REPLICATION, { RECOVERY | NORECOVERY | STANDBY }, REPLACE , RESTART , RESTRICTED_USER , and { STOPAT | STOPATMARK | STOPBEFOREMARK }

Note

The PARTIAL option is supported only by RESTORE DATABASE.

The following table lists the WITH options that are used by one or more statements and indicates which statements support each option. A check mark (√) indicates that an option is supported; a dash (—) indicates that an option is not supported.

WITH option RESTORE RESTORE FILELISTONLY RESTORE HEADERONLY RESTORE LABELONLY RESTORE REWINDONLY RESTORE VERIFYONLY

{ CHECKSUM

| NO_CHECKSUM }

{ CONTINUE_AFTER_ERROR

| STOP_ON_ERROR }

FILE1

LOADHISTORY

MEDIANAME

MEDIAPASSWORD

MOVE

PASSWORD

{ REWIND | NOREWIND }

Only REWIND

Only REWIND

Only REWIND

STATS

{ UNLOAD | NOUNLOAD }

1 FILE **=**backup_set_file_number, which is distinct from {FILE | FILEGROUP}.

Permissions

For permissions, see the following topics:

Examples

For examples, see the following topics:

See Also

Reference

BACKUP (Transact-SQL)
RESTORE (Transact-SQL)
RESTORE FILELISTONLY (Transact-SQL)
RESTORE HEADERONLY (Transact-SQL)
RESTORE LABELONLY (Transact-SQL)
RESTORE REWINDONLY (Transact-SQL)
RESTORE VERIFYONLY (Transact-SQL)

Other Resources

Backing Up and Restoring Databases in SQL Server

Help and Information

Getting SQL Server 2005 Assistance

Change History

Release History

12 December 2006

Changed content:
  • Added descriptions of the BLOCKSIZE, BUFFERCOUNT options MAXTRANSFERSIZE options.
  • Corrected STOPATMARK and STOPBEFOREMARK descriptions.

14 April 2006

New content:
  • Added the "Specifying a Backup Set" section.
  • Added a Note to the STOPATMARK description.
  • Added the following sections, which contain links to other RESTORE topics that contain relevant information:
    • "Syntax"
    • "Remarks"
    • "Result Sets"
    • "Remarks"
    • "Permissions"
    • "Examples"
Changed content:
  • Revised the Note in the STOPAT description.
  • Changed the logical_file_name variable to logical_file_name_in_backup.
  • Updated the descriptions of the {REWIND | NOREWIND} and {UNLOAD | NOUNLOAD} options.

5 December 2005

New content:
  • Added the ENABLE_BROKER and ERROR_BROKER_CONVERSATIONS options.