Skip to content

Latest commit

 

History

History
66 lines (52 loc) · 4.65 KB

checkpoint-transact-sql.md

File metadata and controls

66 lines (52 loc) · 4.65 KB
title description author ms.author ms.date ms.service ms.subservice ms.topic f1_keywords helpviewer_keywords dev_langs
CHECKPOINT (Transact-SQL)
CHECKPOINT (Transact-SQL)
rwestMSFT
randolphwest
07/27/2017
sql
t-sql
reference
CHECKPOINT_TSQL
CHECKPOINT
events [SQL Server], checkpoints
automatic checkpoints
writing dirty pages to disk
pages [SQL Server], dirty
checkpoints [SQL Server]
CHECKPOINT statement
log truncate mode [SQL Server]
dirty pages
logs [SQL Server], checkpoints
manual checkpoints [SQL Server]
pages [SQL Server], checkpoints
TSQL

CHECKPOINT (Transact-SQL)

[!INCLUDE SQL Server Azure SQL Database Azure SQL Managed Instance]

Generates a manual checkpoint in the [!INCLUDEssNoVersion] database to which you are currently connected.

Note

For information about different types of database checkpoints and checkpoint operation in general, see Database Checkpoints (SQL Server).

:::image type="icon" source="../../includes/media/topic-link-icon.svg" border="false"::: Transact-SQL syntax conventions

Syntax

CHECKPOINT [ checkpoint_duration ]  

[!INCLUDEsql-server-tsql-previous-offline-documentation]

Arguments

checkpoint_duration
Specifies the requested amount of time, in seconds, for the manual checkpoint to complete. When checkpoint_duration is specified, the [!INCLUDEssDEnoversion] attempts to perform the checkpoint within the requested duration. The checkpoint_duration must be an expression of type int and must be greater than zero. When this parameter is omitted, the [!INCLUDEssDE] adjusts the checkpoint duration to minimize the performance impact on database applications. checkpoint_duration is an advanced option.

Factors Affecting the Duration of Checkpoint Operations

In general, the amount time required for a checkpoint operation increases with the number of dirty pages that the operation must write. By default, to minimize the performance impact on other applications, [!INCLUDEssNoVersion] adjusts the frequency of writes that a checkpoint operation performs. Decreasing the write frequency increases the time the checkpoint operation requires to complete. [!INCLUDEssNoVersion] uses this strategy for a manual checkpoint unless a checkpoint_duration value is specified in the CHECKPOINT command.

The performance impact of using checkpoint_duration depends on the number of dirty pages, the activity on the system, and the actual duration specified. For example, if the checkpoint would normally complete in 120 seconds, specifying a checkpoint_duration of 45 seconds causes [!INCLUDEssNoVersion] to devote more resources to the checkpoint than would be assigned by default. In contrast, specifying a checkpoint_duration of 180 seconds would cause [!INCLUDEssNoVersion] to assign fewer resources than would be assigned by default. In general, a short checkpoint_duration will increase the resources devoted to the checkpoint, while a long checkpoint_duration will reduce the resources devoted to the checkpoint. [!INCLUDEssNoVersion] always completes a checkpoint if possible, and the CHECKPOINT statement returns immediately when a checkpoint completes. Therefore, in some cases, a checkpoint may complete sooner than the specified duration or may run longer than the specified duration.

Security

Permissions

CHECKPOINT permissions default to members of the sysadmin fixed server role and the db_owner and db_backupoperator fixed database roles, and are not transferable.

See Also

ALTER DATABASE (Transact-SQL)
Database Checkpoints (SQL Server)
Configure the recovery interval Server Configuration Option
SHUTDOWN (Transact-SQL)