Compartir vía


Opciones de ALTER DATABASE SET (Transact-SQL)

Establece opciones de base de datos en Microsoft SQL Server, Azure SQL Database y Azure Synapse Analytics. Para más información sobre otras opciones de ALTER DATABASE, consulte ALTER DATABASE.

Nota:

Establecer algunas opciones con ALTER DATABASE podría requerir acceso exclusivo a la base de datos. Si la instrucción ALTER DATABASE no se completa de forma oportuna, compruebe si otras sesiones de la base de datos bloquean la sesión ALTER DATABASE.

Para más información sobre las convenciones de sintaxis, vea Convenciones de sintaxis de Transact-SQL.

Selección de un producto

En la siguiente fila, seleccione cualquier nombre de producto que le interese. Al hacerlo, en esta página web se muestra otro contenido, adecuado para el producto que seleccione.

* SQL Server *  

 

SQL Server

La creación de reflejo de la base de datos, Grupos de disponibilidad AlwaysOn, y los niveles de compatibilidad son opciones de SET, pero se describen en otros artículos debido a su extensión. Para más información, vea Creación de reflejo de la base de datos de ALTER DATABASE, ALTER DATABASE SET HADR y Nivel de compatibilidad de ALTER DATABASE.

Las configuraciones con ámbito de base de datos se utilizan para establecer varias configuraciones de base de datos en el nivel de base de datos individual. Para obtener más información, vea ALTER DATABASE SCOPED CONFIGURATION.

Nota:

Se pueden configurar muchas opciones SET de la base de datos para la sesión actual mediante instrucciones SET, aunque generalmente las configuran las aplicaciones al realizar la conexión. Las opciones SET de nivel de sesión reemplazan a los valores ALTER DATABASE SET. Las opciones de base de datos descritas en las secciones siguientes son valores que se pueden establecer para sesiones que no proporcionan de forma explícita otros valores de opciones SET.

Sintaxis

ALTER DATABASE { database_name | CURRENT }
SET
{
    <option_spec> [ ,...n ] [ WITH <termination> ]
}

<option_spec> ::=
{
    <accelerated_database_recovery>
  | <auto_option>
  | <automatic_tuning_option>
  | <change_tracking_option>
  | <containment_option>
  | <cursor_option>
  | <database_mirroring_option>
  | <date_correlation_optimization_option>
  | <db_encryption_option>
  | <db_state_option>
  | <db_update_option>
  | <db_user_access_option>
  | <delayed_durability_option>
  | <external_access_option>
  | FILESTREAM ( <FILESTREAM_option> )
  | <HADR_options>
  | <mixed_page_allocation_option>
  | <parameterization_option>
  | <query_store_options>
  | <recovery_option>
  | <remote_data_archive_option>
  | <persistent_log_buffer_option>
  | <service_broker_option>
  | <snapshot_option>
  | <sql_option>
  | <suspend_for_snapshot_backup>
  | <target_recovery_time_option>
  | <termination>
  | <temporal_history_retention>
  | <data_retention_policy>
}
;

<accelerated_database_recovery> ::=
{
    ACCELERATED_DATABASE_RECOVERY = { ON | OFF }
     [ ( PERSISTENT_VERSION_STORE_FILEGROUP = { filegroup name } ) ];
}

<auto_option> ::=
{
    AUTO_CLOSE { ON | OFF }
  | AUTO_CREATE_STATISTICS { OFF | ON [ ( INCREMENTAL = { ON | OFF } ) ] }
  | AUTO_SHRINK { ON | OFF }
  | AUTO_UPDATE_STATISTICS { ON | OFF }
  | AUTO_UPDATE_STATISTICS_ASYNC { ON | OFF }
}

<automatic_tuning_option> ::=
{
    AUTOMATIC_TUNING ( FORCE_LAST_GOOD_PLAN = { DEFAULT | ON | OFF } )
}

<change_tracking_option> ::=
{
    CHANGE_TRACKING
   {
       = OFF
     | = ON [ ( <change_tracking_option_list > [,...n] ) ]
     | ( <change_tracking_option_list> [,...n] )
   }
}

<change_tracking_option_list> ::=
{
   AUTO_CLEANUP = { ON | OFF }
 | CHANGE_RETENTION = retention_period { DAYS | HOURS | MINUTES }
}

<containment_option> ::=
   CONTAINMENT = { NONE | PARTIAL }

<cursor_option> ::=
{
    CURSOR_CLOSE_ON_COMMIT { ON | OFF }
  | CURSOR_DEFAULT { LOCAL | GLOBAL }
}

<database_mirroring_option>
  ALTER DATABASE Database Mirroring

<date_correlation_optimization_option> ::=
    DATE_CORRELATION_OPTIMIZATION { ON | OFF }

<db_encryption_option> ::=
    ENCRYPTION { ON | OFF | SUSPEND | RESUME }

<db_state_option> ::=
    { ONLINE | OFFLINE | EMERGENCY }

<db_update_option> ::=
    { READ_ONLY | READ_WRITE }

<db_user_access_option> ::=
    { SINGLE_USER | RESTRICTED_USER | MULTI_USER }

<delayed_durability_option> ::=
    DELAYED_DURABILITY = { DISABLED | ALLOWED | FORCED }

<external_access_option> ::=
{
    DB_CHAINING { ON | OFF }
  | TRUSTWORTHY { ON | OFF }
  | DEFAULT_FULLTEXT_LANGUAGE = { <lcid> | <language name> | <language alias> }
  | DEFAULT_LANGUAGE = { <lcid> | <language name> | <language alias> }
  | NESTED_TRIGGERS = { OFF | ON }
  | TRANSFORM_NOISE_WORDS = { OFF | ON }
  | TWO_DIGIT_YEAR_CUTOFF = { 1753, ..., 2049, ..., 9999 }
}

<FILESTREAM_option> ::=
{
    NON_TRANSACTED_ACCESS = { OFF | READ_ONLY | FULL
  | DIRECTORY_NAME = <directory_name>
}

<HADR_options> ::=
    ALTER DATABASE SET HADR

<mixed_page_allocation_option> ::=
    MIXED_PAGE_ALLOCATION { OFF | ON }

<parameterization_option> ::=
    PARAMETERIZATION { SIMPLE | FORCED }

<query_store_options> ::=
{
    QUERY_STORE
    {
          = OFF [ ( FORCED ) ]
        | = ON [ ( <query_store_option_list> [,...n] ) ]
        | ( < query_store_option_list> [,...n] )
        | CLEAR [ ALL ]
    }
}

<query_store_option_list> ::=
{
      OPERATION_MODE = { READ_WRITE | READ_ONLY }
    | CLEANUP_POLICY = ( STALE_QUERY_THRESHOLD_DAYS = number )
    | DATA_FLUSH_INTERVAL_SECONDS = number
    | MAX_STORAGE_SIZE_MB = number
    | INTERVAL_LENGTH_MINUTES = number
    | SIZE_BASED_CLEANUP_MODE = { AUTO | OFF }
    | QUERY_CAPTURE_MODE = { ALL | AUTO | CUSTOM | NONE }
    | MAX_PLANS_PER_QUERY = number
    | WAIT_STATS_CAPTURE_MODE = { ON | OFF }
    | QUERY_CAPTURE_POLICY = ( <query_capture_policy_option_list> [,...n] )
}

<query_capture_policy_option_list> :: =
{
      STALE_CAPTURE_POLICY_THRESHOLD = number { DAYS | HOURS }
    | EXECUTION_COUNT = number
    | TOTAL_COMPILE_CPU_TIME_MS = number
    | TOTAL_EXECUTION_CPU_TIME_MS = number
}

<recovery_option> ::=
{
    RECOVERY { FULL | BULK_LOGGED | SIMPLE }
  | TORN_PAGE_DETECTION { ON | OFF }
  | PAGE_VERIFY { CHECKSUM | TORN_PAGE_DETECTION | NONE }
}

<remote_data_archive_option> ::=
{
    REMOTE_DATA_ARCHIVE =
    {
        ON ( SERVER = <server_name>,
             {
                  CREDENTIAL = <db_scoped_credential_name>
                  | FEDERATED_SERVICE_ACCOUNT = ON | OFF
             }
        )
        | OFF
    }
}

<persistent_log_buffer_option> ::=
{
    PERSISTENT_LOG_BUFFER 
    {
          = ON (DIRECTORY_NAME= 'path-to-directory-on-a-DAX-volume')
        | = OFF
    }
}

<service_broker_option> ::=
{
    ENABLE_BROKER
  | DISABLE_BROKER
  | NEW_BROKER
  | ERROR_BROKER_CONVERSATIONS
  | HONOR_BROKER_PRIORITY { ON | OFF }
}

<snapshot_option> ::=
{
    ALLOW_SNAPSHOT_ISOLATION { ON | OFF }
  | READ_COMMITTED_SNAPSHOT { ON | OFF }
  | MEMORY_OPTIMIZED_ELEVATE_TO_SNAPSHOT = { ON | OFF }
}

<sql_option> ::=
{
    ANSI_NULL_DEFAULT { ON | OFF }
  | ANSI_NULLS { ON | OFF }
  | ANSI_PADDING { ON | OFF }
  | ANSI_WARNINGS { ON | OFF }
  | ARITHABORT { ON | OFF }
  | COMPATIBILITY_LEVEL = { 160 | 150 | 140 | 130 | 120 | 110 | 100 }
  | CONCAT_NULL_YIELDS_NULL { ON | OFF }
  | NUMERIC_ROUNDABORT { ON | OFF }
  | QUOTED_IDENTIFIER { ON | OFF }
  | RECURSIVE_TRIGGERS { ON | OFF }
}

<suspend_for_snapshot_backup> ::=
    SET SUSPEND_FOR_SNAPSHOT_BACKUP = { ON | OFF } [ ( MODE = COPY_ONLY ) ]

<target_recovery_time_option> ::=
    TARGET_RECOVERY_TIME = target_recovery_time { SECONDS | MINUTES }

<termination>::=
{
    ROLLBACK AFTER number [ SECONDS ]
  | ROLLBACK IMMEDIATE
  | NO_WAIT
}

<temporal_history_retention> ::=
    TEMPORAL_HISTORY_RETENTION { ON | OFF }

<data_retention_policy> ::=
    DATA_RETENTION { ON | OFF }

Argumentos

database_name

Nombre de la base de datos que se va a modificar.

CURRENT

Se aplica a: SQL Server (a partir de SQL Server 2012 (11.x))

Ejecuta la acción de la base de datos actual. CURRENT no se admite para todas las opciones en todos los contextos. Si CURRENT produce un error, proporcione el nombre de la base de datos.

<accelerated_database_recovery> ::=

Se aplica a: SQL Server (a partir de SQL Server 2019 (15.x))

Habilita recuperación acelerada de bases de datos (ADR). ADR se establece en OFF de forma predeterminada en SQL Server 2019 (15.x) y versiones posteriores. Con esta sintaxis, puede designar un grupo de archivos específico para los datos del Almacén de versiones persistentes (PVS). Si no se especifica ningún grupo de archivos, el PVS se almacena en el grupo de archivos PRIMARY. Para obtener más información, consulte Administración de la recuperación acelerada de bases de datos.

<auto_option> ::=

Controla las opciones automáticas.

AUTO_CLOSE { ON | OFF }

  • ACTIVAR

    La base de datos se cierra correctamente y se liberan sus recursos después de que salga el último usuario.

    La base de datos se vuelve a abrir automáticamente cuando un usuario intenta utilizarla de nuevo. Por ejemplo, este comportamiento se produce cuando un usuario emite una instrucción USE database_name. La base de datos podría apagarse limpiamente con AUTO_CLOSE establecido en ACTIVADO. Si es así, la base de datos no se vuelve a abrir hasta que un usuario intenta usar la base de datos la próxima vez que se reinicie el motor de base de datos.

    Después de apagar una base de datos, cuando una aplicación intente usarla, debe abrirse primero la base de datos para que su estado cambie a en línea. Esto puede tardar algún tiempo y puede dar lugar a tiempos de espera de la aplicación.

  • Apagado

    La base de datos permanece abierta después de que haya salido el último usuario.

    La opción AUTO_CLOSE es útil para las bases de datos de escritorio porque permite administrar los archivos de la base de datos como archivos normales. Se pueden mover, copiar para realizar copias de seguridad e incluso enviar por correo electrónico a otros usuarios. El proceso AUTO_CLOSE es asincrónico. La apertura y cierre repetidos de la base de datos no reduce el rendimiento.

Nota:

La opción AUTO_CLOSE no está disponible en una base de datos independiente o en SQL Database. Para determinar el estado de esta opción, examine la columna is_auto_close_onde la vista de catálogo sys.databases o la propiedad IsAutoClose de la función DATABASEPROPERTYEX.

Cuando AUTO_CLOSE se establece en ON, algunas columnas de la sys.databases vista de catálogo y la función DATABASEPROPERTYEX devuelve NULL porque la base de datos no está disponible para recuperar los datos. Para resolver esta incidencia, ejecute una instrucción USE para abrir la base de datos.

La creación de reflejo de la base de datos requiere que se establezca AUTO_CLOSE en OFF.

Cuando la base de datos se establece en AUTOCLOSE = ON, una operación que inicia el cierre automático de la base de datos borra la memoria caché de planes para la instancia de SQL Server. Al borrar la memoria caché de planes, se provoca una nueva compilación de todos los planes de ejecución posteriores y puede ocasionar una disminución repentina y temporal del rendimiento de las consultas. A partir de SQL Server 2005 (9.x) Service Pack 2, para cada almacén de caché borrado de la caché de planes, el registro de errores de SQL Server contiene el siguiente mensaje informativo: SQL Server has encountered %d occurrence(s) of cachestore flush for the '%s' cachestore (part of plan cache) due to some database maintenance or reconfigure operations. Este mensaje se registra cada cinco minutos siempre que se vacíe la memoria caché dentro de ese intervalo de tiempo.

La configuración de AUTO_CLOSE puede ser una característica útil en algunas situaciones poco frecuentes, por ejemplo, en una instancia de SQL Server sin memoria suficiente para funcionar de forma estable con un gran número de bases de datos o para una instancia heredada de SQL Server de 32 bits con un gran número de bases de datos. En estos escenarios, puede resultar útil habilitar AUTO_CLOSE y conservar los recursos de memoria necesarios para mantener abierta una base de datos cuando no hay ninguna aplicación que use la base de datos. Cuando la base de datos está abierta, se requieren asignaciones de memoria predeterminadas (por ejemplo, estructuras internas para representar varios objetos de metadatos de base de datos y búferes de registro de transacciones).

AUTO_CREATE_STATISTICS { ON | OFF }

  • ACTIVAR

    El optimizador de consultas crea las estadísticas en columnas únicas de los predicados de consulta, según sea necesario, para mejorar los planes de consulta y el rendimiento de las consultas. Estas estadísticas de columna única se crean cuando el optimizador de consultas las compila. Las estadísticas de columna única solamente se crean en las columnas que ya no son la primera columna de un objeto de estadísticas existente.

    El valor predeterminado es ON. Recomendamos utilizar la configuración predeterminada para la mayoría de las bases de datos.

  • Apagado

    El optimizador de consultas no crea estadísticas en columnas únicas de los predicados de consulta cuando se compilan las consultas. Establecer esta opción en OFF puede producir planes de consulta poco óptimos y un rendimiento degradado de las consultas.

Para determinar el estado de esta opción, examine la columna is_auto_create_stats_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAutoCreateStatistics de la función DATABASEPROPERTYEX.

Para más información, vea la sección "Uso de las opciones de estadísticas de toda la base de datos" de Estadísticas.

INCREMENTAL = ON | OFF

Se aplica a: SQL Server (a partir de SQL Server 2014 (12.x)) y Azure SQL Database

Establezca AUTO_CREATE_STATISTICS en ON y establezca INCREMENTAL en ON. Esto crea de forma automática estadísticas como incrementales siempre que se admitan estadísticas incrementales. El valor predeterminado es OFF. Para más información, consulte CREATE STATISTICS.

AUTO_SHRINK { ON | OFF }

  • ACTIVAR

    Los archivos de la base de datos se pueden reducir periódicamente. A menos que tenga un requisito específico, no establezca la opción AUTO_SHRINK base de datos en ACTIVADO. Para más información, consulte Shrink a Database.

    Los archivos de datos y los archivos de registro se pueden reducir de forma automática. AUTO_SHRINK reduce el tamaño del registro de transacciones solo si establece la base de datos en el modelo de recuperación SIMPLE o si realiza una copia de seguridad del registro. Cuando AUTO_SHRINK se establece en OFF, los archivos de la base de datos no se reducen de forma automática durante las comprobaciones periódicas del espacio no utilizado.

    La opción AUTO_SHRINK reduce los archivos cuando no se usa más de un 25 % del espacio del archivo. Reduce el archivo a uno de dos tamaños (el que sea mayor):

    • El tamaño al que el 25 % del archivo es espacio sin usar
    • El tamaño del archivo cuando se creó

    No puede reducir una base de datos de solo lectura.

  • Apagado

    Los archivos de base de datos no se reducen automáticamente durante las comprobaciones periódicas de espacio sin usar.

Para determinar el estado de esta opción, examine la columna is_auto_shrink_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAutoShrink de la función DATABASEPROPERTYEX.

Nota:

La opción AUTO_SHRINK no está disponible en una base de datos independiente.

AUTO_UPDATE_STATISTICS { ON | OFF }

  • ACTIVAR

    Especifica que el optimizador de consultas actualiza las estadísticas cuando las usa una consulta y puedan estar obsoletas. Las estadísticas se vuelven obsoletas después de que operaciones de inserción, actualización, eliminación o combinación cambien la distribución de los datos en la tabla o la vista indizada. Para determinar cuándo las estadísticas pueden quedar obsoletas, el optimizador de consultas cuenta el número de modificaciones de datos desde la actualización más reciente de las estadísticas y compara el número de modificaciones con un umbral. El umbral se basa en el número de filas de la tabla o la vista indizada.

    El optimizador de consultas comprueba si hay estadísticas obsoletas antes de compilar una consulta y ejecuta un plan de consulta almacenado en caché. El optimizador de consultas usa las columnas, tablas y vistas indexadas del predicado de consulta para determinar qué estadísticas podrían estar obsoletas. El optimizador de consultas determina esta información antes de compilar una consulta. Antes de ejecutar un plan de consulta almacenado en caché, Motor de base de datos comprueba que el plan de consulta haga referencia a las estadísticas actualizadas.

    La opción AUTO_UPDATE_STATISTICS se aplica a las estadísticas creadas para índices y columnas únicas de los predicados de consulta, así como a las estadísticas creadas con la instrucción CREATE STATISTICS. Esta opción también se aplica a las estadísticas filtradas.

    El valor predeterminado es ON. Recomendamos utilizar la configuración predeterminada para la mayoría de las bases de datos.

    Utilice la opción AUTO_UPDATE_STATISTICS_ASYNC para especificar si las estadísticas se actualizan sincrónica o asincrónicamente.

  • Apagado

    Especifica que el optimizador de consultas no actualiza las estadísticas cuando una consulta las usa. El optimizador de consultas tampoco actualiza las estadísticas cuando podrían estar obsoletas. Establecer esta opción en OFF puede producir planes de consulta poco óptimos y un rendimiento degradado de las consultas.

Para determinar el estado de esta opción, examine la columna is_auto_update_stats_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAutoUpdateStatistics de la función DATABASEPROPERTYEX.

Para más información, vea la sección "Uso de las opciones de estadísticas de toda la base de datos" de Estadísticas.

AUTO_UPDATE_STATISTICS_ASYNC { ON | OFF }

  • ACTIVAR

    Especifica que las actualizaciones de las estadísticas para la opción AUTO_UPDATE_STATISTICS son asincrónicas. El optimizador de consultas no espera a que finalicen las actualizaciones de las estadísticas para compilar las consultas.

    La configuración de esta opción en ON no surte efecto a menos que AUTO_UPDATE_STATISTICS se establezca en ON.

    De forma predeterminada, la opción AUTO_UPDATE_STATISTICS_ASYNC está configurada en OFF y el optimizador de consultas actualiza las estadísticas de manera sincrónica.

  • Apagado

    Especifica que las actualizaciones de las estadísticas para la opción AUTO_UPDATE_STATISTICS son sincrónicas. El optimizador de consultas espera a que finalicen las actualizaciones de las estadísticas para compilar las consultas.

    Nota:

    La configuración de esta opción en OFF no surte efecto a menos que AUTO_UPDATE_STATISTICS esté configurado en ON.

Para determinar el estado de esta opción, examine la columna is_auto_update_stats_async_on en la vista de catálogo sys.databases.

Para más información sobre cuándo usar las actualizaciones de estadísticas sincrónicas o asincrónicas, vea la sección "Opciones de estadísticas" en Estadísticas.

<automatic_tuning_option> ::=

Se aplica a: SQL Server (a partir de SQL Server 2017 (14.x))

Habilita o deshabilita la opción FORCE_LAST_GOOD_PLAN de . Puede ver el estado de esta opción en la vista sys.database_automatic_tuning_options.

FORCE_LAST_GOOD_PLAN = { DEFAULT | ON | OFF }

  • DEFAULT

    El valor predeterminado de SQL Server es OFF.

  • ACTIVAR

    Motor de base de datos fuerza automáticamente el último buen plan conocido en las consultas de Transact-SQL, donde el nuevo plan de consulta provoca regresiones de rendimiento. El parámetro Motor de base de datos supervisa continuamente el rendimiento de la consulta Transact-SQL con el plan forzado.

    Si hay mejoras de rendimiento, el motor de base de datos sigue usando el último plan correcto conocido. Si no se detectan mejoras de rendimiento, el motor de base de datos genera un nuevo plan de consulta. Se produce un error en la instrucción si la del Almacén de consultas de no está habilitada o si el Almacén de consultas no está en modo lectura y escritura.

  • Apagado

    Motor de base de datos informa de posibles regresiones de rendimiento de consultas provocadas por cambios del plan de consulta en la vista sys.dm_db_tuning_recommendations, Sin embargo, estas recomendaciones no se aplican automáticamente. Para supervisar las recomendaciones activas y corregir los problemas identificados, los usuarios pueden aplicar los scripts de Transact-SQL que se muestran en la vista. El valor predeterminado es OFF.

<change_tracking_option> ::=

Se aplica a: SQL Server y Azure SQL Database

Controla las opciones de seguimiento de cambios. Puede habilitar el seguimiento de cambios, establecer y cambiar opciones, y deshabilitar el seguimiento de cambios. Para obtener ejemplos, vea la sección Ejemplos más adelante en este artículo.

  • ACTIVAR

    Habilita el seguimiento de cambios para la base de datos. Si habilita el seguimiento de cambios, también puede establecer las opciones AUTO CLEANUP y CHANGE RETENTION.

  • AUTO_CLEANUP = { ON | OFF }

    • ACTIVAR

      La información sobre el seguimiento de cambios se quita de forma automática después del período de retención especificado.

    • Apagado

      Los datos del seguimiento de cambios no se quitan automáticamente de la base de datos.

  • CHANGE_RETENTION = período_de_retención { DAYS | HOURS | MINUTES }

    Especifica el período mínimo para mantener la información del seguimiento de cambios en la base de datos. Los datos solamente se quitan cuando el valor AUTO_CLEANUP es ON.

    retention_period es un entero que especifica el componente numérico del período de retención.

    El período de retención predeterminado es de 2 días. El período de retención mínimo es de 1 minuto. El tipo de retención predeterminado es DAYS.

  • OFF Deshabilita el seguimiento de cambios para la base de datos. Deshabilite el seguimiento de cambios en todas las tablas para poder deshabilitarlo en la base de datos.

<containment_option> ::=

Se aplica a: SQL Server (a partir de SQL Server 2012 (11.x))

Controla las opciones de contención de la base de datos.

CONTAINMENT = { NONE | PARTIAL}

  • Ninguno

    La base de datos no es una base de datos independiente.

  • PARTIAL

    La base de datos es una base de datos independiente. Se produce un error al establecer la contención de la base de datos en parcial si la base de datos tiene habilitada la replicación, la captura de datos modificados o el seguimiento de cambios. La comprobación de errores se detiene después de un error. Para obtener más información acerca de las bases de datos independientes, vea Contained Databases.

<cursor_option> ::=

Controla las opciones del cursor.

CURSOR_CLOSE_ON_COMMIT { ON | OFF }

  • ACTIVAR

    Todos los cursores abiertos cuando confirma o deshace una transacción se cierran.

  • Apagado

    Los cursores permanecen abiertos cuando se confirma una transacción; Revertir una transacción cierra los cursores, excepto los que se definen como INSENSITIVE o STATIC.

La configuración del nivel de conexión, establecida mediante la instrucción SET, invalida la configuración predeterminada de la base de datos para CURSOR_CLOSE_ON_COMMIT. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión que establece CURSOR_CLOSE_ON_COMMIT en OFF para la sesión. Los clientes ejecutan la instrucción cuando se conecta a una instancia de SQL Server. Para más información, consulte SET CURSOR_CLOSE_ON_COMMIT.

Para determinar el estado de esta opción, examine la columna is_cursor_close_on_commit_onde la vista de catálogo sys.databases o la propiedad IsCloseCursorsOnCommitEnabled de la función DATABASEPROPERTYEX.

CURSOR_DEFAULT { LOCAL | GLOBAL }

Se aplica a: SQL Server

Controla si el ámbito del cursor utiliza LOCAL o GLOBAL.

  • LOCAL

    Cuando especifica LOCAL y no define un cursor como GLOBAL cuando crea el cursor, el alcance del cursor es local. Específicamente, el alcance es local para el proceso por lotes, el procedimiento almacenado o el activador en el que creó el cursor. El nombre del cursor solamente es válido dentro de este ámbito.

    Es posible hacer referencia al cursor mediante variables de cursor locales del lote, procedimiento almacenado, desencadenador o parámetro OUTPUT del procedimiento almacenado. La asignación del cursor se desasigna implícitamente cuando el lote, el procedimiento almacenado o el desencadenador finaliza. El cursor se desasigna a menos que se haya pasado de nuevo en un parámetro OUTPUT. El cursor se podría pasar en un parámetro OUTPUT. Si el cursor se vuelve a pasar de esta forma, se desasigna cuando la última variable que hace referencia a él se desasigna o se sale del ámbito.

  • GLOBAL

    Si se especifica GLOBAL y no se define ningún cursor como LOCAL al crearlo, el ámbito del cursor es global para la conexión. Se puede hacer referencia al nombre del cursor en cualquier procedimiento almacenado o lote que se ejecute durante la conexión.

    El cursor se desasigna implícitamente solamente cuando se realiza la desconexión. Para más información, consulte DECLARE CURSOR.

Para determinar el estado de esta opción, examine la columna is_local_cursor_default en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsLocalCursorsDefault de la función DATABASEPROPERTYEX.

<temporal_history_retention> ::=

TEMPORAL_HISTORY_RETENTION { ON | OFF }

ON es el valor predeterminado, pero también se establece automáticamente en OFF después de una operación de restauración a un momento dado. Para obtener más información, incluido cómo habilitar esta configuración, consulte Configuración de la directiva de retención.

<data_retention_policy> ::=

Se aplica a: Solo Azure SQL Edge.

DATA_RETENTION { ON | OFF }

  • ACTIVAR

    Habilita la limpieza basada en la directiva de retención de datos en una base de datos.

  • Apagado

    Deshabilita la limpieza basada en la directiva de retención de datos en una base de datos.

<database_mirroring>

Se aplica a: SQL Server

Para las descripciones del argumento, consulte Creación de reflejo de la base de datos de ALTER DATABASE.

<date_correlation_optimization_option> ::=

Se aplica a: SQL Server

Controla la opción date_correlation_optimization.

DATE_CORRELATION_OPTIMIZATION { ON | OFF }

  • ACTIVAR

    SQL Server mantiene estadísticas de correlación donde una restricción FOREIGN KEY vincula dos tablas cualesquiera en la base de datos y las tablas tienen columnas datetime.

  • Apagado

    No se mantienen las estadísticas de correlación.

Para establecer DATE_CORRELATION_OPTIMIZATION en ON, no debe haber ninguna conexión activa con la base de datos, salvo la que ejecuta la instrucción ALTER DATABASE. Después se admitirán múltiples conexiones.

El valor actual de esta opción se puede determinar mediante el examen de la columna is_date_correlation_on en la vista de catálogo sys.databases.

<db_encryption_option> ::=

Controla el estado del cifrado de la base de datos.

ENCRYPTION { ON | OFF | SUSPEND | RESUME }

  • ACTIVAR

    Establece la base de datos que se va a cifrar.

  • Apagado

    Establece la base de datos que no se va a cifrar.

  • SUSPEND

    Se aplica a: SQL Server (a partir de SQL Server 2019 (15.x))

    Se puede usar para pausar el examen de cifrado después de habilitar o deshabilitar el cifrado de datos transparente, o después de cambiar la clave de cifrado.

  • RESUME

    Se aplica a: SQL Server (a partir de SQL Server 2019 (15.x))

    Se puede usar para reanudar un examen de cifrado pausado anteriormente.

Para más información sobre el cifrado de bases de datos, consulte cifrado de datos transparente (TDE)y Cifrado de datos transparente para Azure SQL Database, Azure SQL Managed Instance y Azure Synapse Analytics.

Cuando el cifrado está habilitado en el nivel de base de datos, todos los grupos de archivos se cifran. Los nuevos grupos de archivos heredan la propiedad cifrada. Si algún grupo de archivos de la base de datos se establece en READ ONLY, se produce un error en la operación de cifrado de la base de datos.

Puede ver el estado del cifrado de la base de datos, así como el estado del análisis de cifrado, mediante la vista de administración dinámica sys.dm_database_encryption_keys.

<db_state_option> ::=

Se aplica a: SQL Server

Controla el estado de la base de datos.

  • OFFLINE

    La base de datos está cerrada, se ha cerrado correctamente y se ha marcado como sin conexión. La base de datos no se puede modificar mientras está desconectada.

  • ONLINE

    La base de datos está abierta y disponible para su uso.

  • EMERGENCY

    La base de datos está marcada como READ_ONLY, el registro está deshabilitado y el acceso está limitado a miembros del rol fijo de servidor sysadmin. EMERGENCY se utiliza principalmente para la solución de problemas. Por ejemplo, una base de datos marcada como sospechosa debido a un archivo de registro dañado se puede establecer en el estado EMERGENCY. Este valor puede habilitar el acceso de solo lectura del administrador del sistema a la base de datos. Solamente los miembros del rol fijo de servidor sysadmin pueden establecer una base de datos en el estado EMERGENCY.

Necesita el permiso ALTER DATABASE para la base de datos de asunto, para cambiar una base de datos al estado sin conexión o de emergencia, y el permiso ALTER ANY DATABASE de nivel de servidor para conectar una base de datos que estaba sin conexión.

Para determinar el estado de esta opción, examine las columnas state y state_desc en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad Status de la función DATABASEPROPERTYEX. Para más información, consulte Database States.

Una base de datos marcada como RESTORING no se puede establecer como OFFLINE, ONLINE o EMERGENCY. Una base de datos podría estar en estado RESTORE durante una operación de restauración activa o cuando se produce un error en una operación de restauración de una base de datos o un archivo de registro debido a un archivo de copia de seguridad dañado.

<db_update_option> ::=

Controla si se permiten las actualizaciones en la base de datos.

  • READ_ONLY

    Los usuarios pueden leer datos de la base de datos, pero no pueden modificarlos.

    Nota:

    Para mejorar el rendimiento de las consultas, actualice las estadísticas antes de establecer una base de datos en READ_ONLY. Si se necesitan estadísticas adicionales después de establecer una base de datos en READ_ONLY, el motor de base de datos crea estadísticas en la base de datos del sistema tempdb. Para más información sobre las estadísticas para una base de datos de solo lectura, vea Utilizar las estadísticas para mejorar el rendimiento de las consultas.

  • READ_WRITE

    La base de datos está disponible para operaciones de lectura y escritura.

Para cambiar este estado, debe tener acceso exclusivo a la base de datos. Para obtener más información, vea la cláusula SINGLE_USER.

Nota:

En las bases de datos federadas de Azure SQL Database, SET { READ_ONLY | READ_WRITE } está deshabilitado.

<db_user_access_option> ::=

Controla el acceso del usuario a la base de datos.

SINGLE_USER

Se aplica a: SQL Server

Especifica que solamente puede tener acceso a la base de datos un usuario cada vez. Si especifica SINGLE_USER y otro usuario se conecta a la base de datos, la instrucción ALTER DATABASE se bloquea hasta que todos los usuarios se desconecten de la base de datos especificada. Para invalidar este comportamiento, vea la cláusula WITH <termination>.

La base de datos permanece en modo SINGLE_USER incluso si el usuario que estableció la opción cierra la sesión. A partir de ese momento, un usuario distinto, pero solo uno, puede conectarse a la base de datos.

Antes de establecer la base de datos como SINGLE_USER, compruebe que la opción AUTO_UPDATE_STATISTICS_ASYNC está establecida en OFF. Cuando se establece en ON, el subproceso en segundo plano usado para actualizar las estadísticas toma una conexión con la base de datos y no puede acceder a la base de datos en modo de usuario único. Para ver el estado de esta opción, consulte la columna is_auto_update_stats_async_on en la vista de catálogo sys.databases. Si la opción está establecida en ON, realice las tareas siguientes:

  1. Establezca AUTO_UPDATE_STATISTICS_ASYNC en OFF.

  2. Compruebe si hay trabajos de estadísticas asincrónicos consultando la vista de administración dinámica sys.dm_exec_background_job_queue.

Si hay trabajos activos, permita que estos se completen o termínelos de forma manual mediante KILL STATS JOB.

RESTRICTED_USER

Solo permite a los miembros del rol fijo de base de datos db_owner y de los roles fijos de servidor dbcreator y sysadmin conectarse a la base de datos. RESTRICTED_USER no limita su número. Desconecte todas las conexiones con la base de datos mediante el margen de tiempo especificado por la cláusula de terminación de la instrucción ALTER DATABASE. Una vez que la base de datos ha cambiado al estado RESTRICTED_USER, se rechazan los intentos de conexión por parte de usuarios no cualificados.

MULTI_USER

Todos los usuarios que tengan los permisos correspondientes pueden conectarse a la base de datos. Para determinar el estado de esta opción, examine la columna user_access en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad UserAccess de la función DATABASEPROPERTYEX.

<delayed_durability_option> ::=

Se aplica a: SQL Server (a partir de SQL Server 2014 (12.x))

Controla si las transacciones se confirman con perdurabilidad total o diferida.

  • DISABLED

    Todas las transacciones tras SET DISABLED son totalmente perdurables. Se omiten las opciones de perdurabilidad que se establecen en un bloque ATOMIC o en una instrucción de confirmación.

  • ALLOWED

    Todas las transacciones tras SET ALLOWED son totalmente perdurables o de perdurabilidad diferida, dependiendo de la opción de perdurabilidad establecida en el bloque ATOMIC o la instrucción de confirmación.

  • FORCED

    Todas las transacciones tras SET FORCED son de perdurabilidad diferida. Se omiten las opciones de perdurabilidad que se establecen en un bloque ATOMIC o en una instrucción de confirmación.

<external_access_option> ::=

Se aplica a: SQL Server

Controla si recursos externos como los objetos de otra base de datos pueden tener acceso a la base de datos.

DB_CHAINING { ON | OFF }

  • ACTIVAR

    La base de datos puede ser el origen o el destino de un encadenamiento de propiedad entre bases de datos.

  • Apagado

    La base de datos no puede participar en el encadenamiento de propiedad entre bases de datos.

Importante

La instancia de SQL Server reconoce esta configuración cuando la opción del servidor de encadenamiento de propiedad entre bases de datos es 0 (OFF). Si cross db ownership chaining es 1 (ON), todas las bases de datos de usuario pueden participar en cadenas de propiedad entre bases de datos, independientemente del valor de esta opción. Esta opción se establece mediante sp_configure.

Para establecer esta opción, se requiere el permiso de CONTROL SERVER en la base de datos.

La opción DB_CHAINING no se puede establecer en las bases de datos del sistema master, model y tempdb.

Para determinar el estado de esta opción, examine la columna is_db_chaining_on en la vista de catálogo sys.databases.

TRUSTWORTHY { ON | OFF }

  • ACTIVAR

    Los módulos de base de datos (por ejemplo, las funciones definidas por el usuario o los procedimientos almacenados) que utilizan un contexto de suplantación pueden tener acceso a recursos externos a la base de datos.

  • Apagado

    Los módulos de base de datos en un contexto de suplantación no pueden tener acceso a recursos externos a la base de datos.

    TRUSTWORTHY se establece en OFF siempre que la base de datos se adjunta.

De forma predeterminada, el valor TRUSTWORTHY se establece en OFF en todas las bases de datos de sistema, excepto en msdb. El valor no se puede cambiar en las bases de datos model ni tempdb. Se recomienda no establecer la opción TRUSTWORTHY en ON en la base de datos master.

Para establecer esta opción, se requiere el permiso de CONTROL SERVER en la base de datos.

Para determinar el estado de esta opción, examine la columna is_trustworthy_on en la vista de catálogo sys.databases.

DEFAULT_FULLTEXT_LANGUAGE

Se aplica a: SQL Server (a partir de SQL Server 2012 (11.x))

Especifica el valor de idioma predeterminado para las columnas indizadas de texto completo.

Importante

Esta opción solo se permite cuando CONTAINMENT se ha establecido en PARTIAL. Si CONTAINMENT se establece en NONE, se producen errores.

DEFAULT_LANGUAGE

Se aplica a: SQL Server (a partir de SQL Server 2012 (11.x))

Especifica el idioma predeterminado de los nuevos inicios de sesión creados. El idioma se puede especificar proporcionando el identificador local (LCID), el nombre de idioma o el alias de idioma. Para una lista de nombres y alias de idioma aceptables, consulte sys.syslanguages. Esta opción solo se permite cuando CONTAINMENT se ha establecido en PARTIAL. Si CONTAINMENT se establece en NONE, se producen errores.

NESTED_TRIGGERS

Se aplica a: SQL Server (a partir de SQL Server 2012 (11.x))

Especifica si un desencadenador AFTER puede actuar en cascada; es decir, realizar una acción que inicia otro desencadenador que, a su vez, inicia otro desencadenador, etc. Esta opción solo se permite cuando CONTAINMENT se ha establecido en PARTIAL. Si CONTAINMENT se establece en NONE, se producen errores.

TRANSFORM_NOISE_WORDS

Se aplica a: SQL Server (a partir de SQL Server 2012 (11.x))

Se utiliza para suprimir un mensaje de error si las palabras irrelevantes producen un error en una operación booleana en una consulta de texto completo. Esta opción solo se permite cuando CONTAINMENT se ha establecido en PARTIAL. Si CONTAINMENT se establece en NONE, se producen errores.

TWO_DIGIT_YEAR_CUTOFF

Se aplica a: SQL Server (a partir de SQL Server 2012 (11.x))

Especifica un número entero comprendido entre 1753 y 9999 que representa el año límite para interpretar años de dos dígitos como años de cuatro dígitos. Esta opción solo se permite cuando CONTAINMENT se ha establecido en PARTIAL. Si CONTAINMENT se establece en NONE, se producen errores.

<FILESTREAM_option> ::=

Se aplica a: SQL Server (a partir de SQL Server 2012 (11.x))

Controla los valores de objetos FileTable.

NON_TRANSACTED_ACCESS = { OFF | READ_ONLY | FULL }

  • Apagado

    El acceso no transaccional a los datos de FileTable está deshabilitado.

  • READ_ONLY

    Los procesos no transaccionales pueden leer datos FILESTREAM en los objetos FileTable de esta base de datos.

  • FULL

    Permite el acceso no transaccional completo a datos de FILESTREAM en objetos FileTable.

DIRECTORY_NAME = <directory_name>

Un nombre de directorio compatible con Windows. Este nombre debe ser único entre todos los nombres de directorio de nivel de base de datos en la instancia de SQL Server. La comparación de unicidad no distingue mayúsculas de minúsculas, independientemente de la configuración de intercalación. Esta opción se debe establecer antes de crear un objeto FileTable en esta base de datos.

<HADR_options> ::=

Se aplica a: SQL Server

Consulte ALTER DATABASE SET HADR.

<mixed_page_allocation_option> ::=

Se aplica a: SQL Server (a partir de SQL Server 2016 (13.x))

Controla si la base de datos puede crear páginas iniciales con una extensión mixta para las primeras ocho páginas de una tabla o un índice.

MIXED_PAGE_ALLOCATION { OFF | ON }

  • Apagado

    La base de datos siempre crea páginas iniciales mediante extensiones uniformes. OFF Es el valor predeterminado.

  • ACTIVAR

    La base de datos puede crear páginas iniciales mediante extensiones mixtas.

Esta opción es ON para todas las bases de datos del sistema. La base de datos del sistema tempdb es la única base de datos del sistema que admite OFF.

<PARAMETERIZATION_option> ::=

Controla la opción de parametrización. Para obtener más información sobre la parametrización, vea la Guía de arquitectura de procesamiento de consultas.

PARAMETERIZATION { SIMPLE | FORCED }

  • SIMPLE

    Las consultas incluyen parámetros en función del comportamiento predeterminado de la base de datos.

  • FORCED

    SQL Server incluye parámetros para todas las consultas de la base de datos.

El valor actual de esta opción se puede determinar mediante el examen de la columna is_parameterization_forced en la vista de catálogo sys.databases.

<query_store_options> ::=

Se aplica a: SQL Server (a partir de SQL Server 2016 (13.x))

ON | OFF [ ( FORCED ) ] | CLEAR [ ALL ]

Controla si el almacén de consultas está habilitado en esta base de datos y también controla la eliminación del contenido del almacén de consultas. Para obtener más información, vea Escenarios de uso del Almacén de consultas.

  • ACTIVAR

    Habilita el Almacén de consultas.

    Muchas características nuevas de rendimiento de SQL Server 2022 (16.x), como sugerencias del Almacén de consultas, comentarios de CE, comentarios de grado de paralelismo (DOP) y persistencia de comentarios de concesión de memoria (MGF) necesitaban que el almacén de consultas estuviera habilitado. Para las bases de datos que se han restaurado desde otras instancias de SQL Server y para las bases de datos que se actualizan desde una actualización local a SQL Server 2022 (16.x), estas bases de datos conservan la configuración anterior del Almacén de consultas. Si hay alguna preocupación por la sobrecarga que puede introducir el Almacén de consultas, los administradores pueden aprovechar directivas de captura personalizadas con QUERY_CAPTURE_MODE = CUSTOM. Para obtener ejemplos de cómo habilitar el Almacén de consultas con opciones de directiva de captura personalizada, consulte la sección Ejemplos más adelante en este artículo.

  • OFF [ ( FORCED ) ]

    Deshabilita el Almacén de consultas. FORCED es opcional. FORCED anula todas las tareas en segundo plano del Almacén de consultas en ejecución y omite el vaciado sincrónico cuando se desactiva el Almacén de consultas. Hace que el Almacén de consultas se apague lo más rápido posible. FORCED se aplica a SP2 CU14 de SQL Server 2016 (13.x), CU21 de SQL Server 2017 (14.x), CU6 de SQL Server 2019 (15.x) y a las compilaciones posteriores.

    Nota:

    El Almacén de consultas no se puede deshabilitar en Azure SQL Database. Al ejecutar ALTER DATABASE [database] SET QUERY_STORE = OFF devuelve la advertencia 'QUERY_STORE=OFF' is not supported in this version of SQL Server..

  • CLEAR [ ALL ]

    Quita los datos relacionados con las consultas del Almacén de consultas. ALL es opcional. ALL quita los datos y metadatos relacionados con las consultas del Almacén de consultas.

OPERATION_MODE { READ_ONLY | READ_WRITE }

Describe el modo de operación del Almacén de consultas.

READ_WRITE

El Almacén de consultas recopila y continúa el plan de consultas y la información de estadística del tiempo de ejecución.

READ_ONLY

La información se puede leer del almacén de consultas, pero no se agrega información nueva. Si se ha agotado el espacio máximo emitido del Almacén de consultas, el Almacén de consultas cambia el modo de operación a READ_ONLY.

CLEANUP_POLICY

Describe la directiva de retención de datos del Almacén de consultas. STALE_QUERY_THRESHOLD_DAYS determina el número de días durante los que se conserva la información de una consulta en el Almacén de consultas. STALE_QUERY_THRESHOLD_DAYS es de tipo bigint. El valor predeterminado es 30.

DATA_FLUSH_INTERVAL_SECONDS

Determina la frecuencia con la que los datos escritos en el Almacén de consultas se conservan en el disco. Para optimizar el rendimiento, los datos recopilados por el Almacén de consultas se escriben de manera asincrónica en el disco. La frecuencia con la que se produce esta transferencia asincrónica se configura mediante el argumento DATA_FLUSH_INTERVAL_SECONDS. DATA_FLUSH_INTERVAL_SECONDS es de tipo bigint. El valor predeterminado es 900 (15 minutos).

MAX_STORAGE_SIZE_MB

Determina el espacio emitido en el Almacén de consultas. MAX_STORAGE_SIZE_MB es de tipo bigint. El valor predeterminado es de 100 MB para SQL Server (SQL Server 2016 (13.x) hasta SQL Server 2017 (14.x)). A partir de SQL Server 2019 (15.x), el valor predeterminado es de 1000 MB.

El límite MAX_STORAGE_SIZE_MB no se aplica de forma estricta. El tamaño de almacenamiento solo se comprueba cuando el almacén de consultas escribe datos en el disco. Este intervalo se establece mediante la opción DATA_FLUSH_INTERVAL_SECONDS o la opción de diálogo Intervalo de vaciado de datos del Almacén de consultas de Management Studio. El valor predeterminado de intervalo es 900 segundos (o 15 minutos).

Si el Almacén de consultas ha infringido el límite de MAX_STORAGE_SIZE_MB entre las comprobaciones de tamaño de almacenamiento, realiza la transición al modo de solo lectura. Si SIZE_BASED_CLEANUP_MODE está habilitado, también se desencadena el mecanismo de limpieza para aplicar el límite de MAX_STORAGE_SIZE_MB.

Una vez que se ha borrado suficiente espacio, el modo almacén de consultas cambia automáticamente a lectura y escritura.

Importante

Si cree que la captura de carga de trabajo necesita más de 10 GB de espacio en disco, probablemente debería replantear y optimizar la carga de trabajo para reutilizar los planes de consulta (por ejemplo, mediante parametrización forzadao ajustar las configuraciones del Almacén de consultas. A partir de SQL Server 2019 (15.x) y en Azure SQL Database, puede establecer QUERY_CAPTURE_MODE en PERSONALIZADO para obtener un control adicional sobre la directiva de captura de consultas.

INTERVAL_LENGTH_MINUTES

Determina el intervalo de tiempo en el que se agregan los datos de estadísticas de ejecución en tiempo de ejecución al Almacén de consultas. Para optimizar el uso del espacio, se agregan las estadísticas de ejecución en tiempo de ejecución en el almacén de estadísticas de tiempo de ejecución en una ventana de tiempo fijo. Esta ventana de tiempo fijo se configura con el argumento INTERVAL_LENGTH_MINUTES. INTERVAL_LENGTH_MINUTES es de tipo bigint. El valor predeterminado es 60.

SIZE_BASED_CLEANUP_MODE { AUTO | OFF }

Controla si la limpieza se activa de forma automática cuando la cantidad total de datos se acerca al tamaño máximo.

  • AUTO

    La limpieza basada en tamaño se activa automáticamente cuando el tamaño del disco alcanza los 90% de MAX_STORAGE_SIZE_MB. La limpieza según el tamaño quita primero las consultas menos caras y más antiguas. Se detiene aproximadamente en el 80 % de MAX_STORAGE_SIZE_MB. Este es el valor de configuración predeterminado.

  • Apagado

    La limpieza basada en tamaño no se activa automáticamente.

SIZE_BASED_CLEANUP_MODE es de tipo nvarchar.

QUERY_CAPTURE_MODE { ALL | AUTO | CUSTOM | NONE }

Designa el modo de captura de consulta que está activo. Cada modo define directivas de captura de consulta específicas. QUERY_CAPTURE_MODE es de tipo nvarchar.

Nota:

Los cursores, las consultas dentro de procedimientos almacenados y las consultas compiladas de forma nativa siempre se capturan cuando el modo de captura de consulta se establece en ALL, AUTO o CUSTOM.

  • ALL

    Captura todas las consultas. ALL es el valor de configuración predeterminado para SQL Server (SQL Server 2016 (13.x) hasta SQL Server 2017 (14.x)).

  • AUTO

    Captura consultas pertinentes en función del consumo de recursos y el recuento de ejecuciones. Este es el valor de configuración predeterminado para SQL Server (a partir de SQL Server 2019 (15.x)) y Azure SQL Database.

  • Ninguno

    Detiene la captura de nuevas consultas. El Almacén de consultas sigue recopilando estadísticas de compilación y tiempo de ejecución para las consultas que ya se capturaron. Use esta configuración con precaución, ya que es posible que no capture consultas importantes.

  • CUSTOM

    Se aplica a: SQL Server (a partir de SQL Server 2019 (15.x))

    Permite controlar las opciones de QUERY_CAPTURE_POLICY. Las directivas de captura personalizada pueden ayudar al almacén de consultas a capturar las consultas más importantes de la carga de trabajo. Consulte <query_capture_policy_option_list> para ver las opciones personalizables.

max_plans_per_query

Define el número máximo de planes que se tienen para cada consulta. MAX_PLANS_PER_QUERY es del tipo int. El valor predeterminado es 200.

WAIT_STATS_CAPTURE_MODE { ON | OFF }

Se aplica a: SQL Server (a partir de SQL Server 2017 (14.x)))

Controla si las estadísticas de espera se capturan por consulta.

  • ACTIVAR

    Se captura información de estadísticas de espera por consulta. Este es el valor de configuración predeterminado.

  • Apagado

    No se captura la información de estadísticas de espera por consulta.

<query_capture_policy_option_list> :: =

Se aplica a: SQL Server (a partir de SQL Server 2019 (15.x))

Controla las opciones de directiva de captura del almacén de consultas. Excepto en STALE_CAPTURE_POLICY_THRESHOLD, estas opciones definen las condiciones OR que se tienen que dar para que las consultas se capturen en el valor definido en el umbral de la directiva de capturas obsoletas.

A partir de SQL Server 2019 (15.x), la QUERY_CAPTURE_MODE = AUTO configuración captura Almacén de consultas detalles cuando se alcanza cualquiera de los umbrales siguientes:

  • EXECUTION_COUNT = 30 ejecuciones = recuento de ejecuciones
  • TOTAL_COMPILE_CPU_TIME_MS = 1 segundo = tiempo de compilación en milisegundos
  • TOTAL_EXECUTION_CPU_TIME_MS = 100 ms = tiempo de CPU de ejecución en milisegundos

Por ejemplo:

EXECUTION_COUNT = 30,
TOTAL_COMPILE_CPU_TIME_MS = 1000,
TOTAL_EXECUTION_CPU_TIME_MS = 100

Puede personalizar estas opciones con QUERY_CAPTURE_MODE = CUSTOM:

  • STALE_CAPTURE_POLICY_THRESHOLD = entero { DAYS | HOURS }

    Define el período de intervalo de evaluación para determinar si se debe capturar una consulta. El valor predeterminado es de 1 día y puede establecerse de 1 hora a 7 días.

  • EXECUTION_COUNT = entero

    Define el número de veces que se ejecuta una consulta durante el período de evaluación. El valor predeterminado es 30, lo que significa que, para el valor predeterminado del umbral de la directiva de capturas obsoletas, una consulta se tendrá que ejecutar al menos 30 veces en un día para que se conserve en el almacén de consultas. EXECUTION_COUNT es del tipo int.

  • TOTAL_COMPILE_CPU_TIME_MS = entero

    Define el tiempo total de CPU de compilación transcurrido que usa una consulta durante el período de evaluación. El valor predeterminado es 1000, lo que significa que, para el valor predeterminado del umbral de la directiva de capturas obsoletas, una consulta tendrá que invertir un total de al menos un segundo de tiempo de CPU durante la compilación de consulta en un día para conservarse en el Almacén de consultas. TOTAL_COMPILE_CPU_TIME_MS es del tipo int.

  • TOTAL_EXECUTION_CPU_TIME_MS = entero

    Define el tiempo de ejecución total de CPU transcurrido que ha utilizado una consulta durante el período de evaluación. El valor predeterminado es 100, lo que significa que, para el valor predeterminado del umbral de la directiva de capturas obsoletas, una consulta tendrá que invertir un total de al menos 100 ms de tiempo de CPU durante la ejecución en un día para que se conserve en el almacén de consultas. TOTAL_EXECUTION_CPU_TIME_MS es del tipo int.

<recovery_option> ::=

Se aplica a: SQL Server

Controla las opciones de recuperación de base de datos y la comprobación de errores de E/S de disco.

  • FULL

    Proporciona una restauración completa tras un error del medio, utilizando copias de seguridad del registro de transacciones. Si un archivo de datos está dañado, la recuperación del medio puede restaurar todas las transacciones confirmadas. Para obtener más información, consulte Modelos de recuperación.

  • BULK_LOGGED

    Proporciona una recuperación tras un error del medio. Combina el máximo rendimiento y la mínima cantidad de uso de espacio de registro para determinadas operaciones a gran escala o masivas. Para obtener información sobre las operaciones que se pueden registrar mínimamente, consulte El registro de transacciones. En el modelo de recuperación BULK_LOGGED, el registro de estas operaciones es mínimo. Para obtener más información, consulte Modelos de recuperación.

  • SIMPLE

    Se proporciona una estrategia de copia de seguridad sencilla que utiliza un espacio de registro mínimo. Se puede volver a utilizar el espacio de registro de forma automática cuando ya no se necesite para la recuperación tras errores del servidor. Para obtener más información, consulte Modelos de recuperación.

    Importante

    El modelo de recuperación simple es más fácil de administrar que los otros dos modelos, pero a costa de un mayor riesgo de perder los datos si se daña un archivo de datos. Todos los cambios se pierden, desde la copia de seguridad de base de datos más reciente o desde la copia de seguridad diferencial de la base de datos, y se deben volver a incluir de forma manual.

El modelo de recuperación predeterminado se determina mediante el modelo de recuperación de la base de datos del sistema model. Para obtener más información sobre cómo seleccionar el modelo de recuperación adecuado, consulte Modelos de recuperación.

Para determinar el estado de esta opción, examine las columnas recovery_model y recovery_model_desc en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad Recovery de la función DATABASEPROPERTYEX.

TORN_PAGE_DETECTION { ON | OFF }

  • ACTIVAR

    Las páginas incompletas se pueden detectar mediante el Motor de base de datos.

  • Apagado

    Las páginas incompletas no se pueden detectar mediante el Motor de base de datos.

Importante

La estructura de sintaxis TORN_PAGE_DETECTION ON | OFF se quitará en una versión futura de SQL Server. Evite utilizar esta estructura de sintaxis en nuevos trabajos de desarrollo y prevea modificar las aplicaciones que actualmente la utilizan. Utilice la opción PAGE_VERIFY en su lugar.

PAGE_VERIFY { CHECKSUM | TORN_PAGE_DETECTION | NONE }

Detecta páginas de bases de datos dañadas por errores de ruta de E/S de disco. Los errores de ruta de acceso de E/S de disco pueden ser la causa de problemas de daños en la base de datos. Estos errores suelen producirse por errores de alimentación o errores de hardware de disco que ocurren en el momento en el que la página se escribe en disco.

  • CHECKSUM

    Calcula una suma de comprobación del contenido de toda la página y almacena el valor en el encabezado de página si se escribe una página en el disco. Si la página se lee desde el disco, la suma de comprobación se vuelve a calcular y se compara con el valor de suma de comprobación almacenado en el encabezado de página. Si el valor no coincide, se genera el mensaje de error 824 (indica un error de la suma de comprobación) para el registro de errores de SQL Server, así como para el registro de eventos de Windows. Un error de la suma de comprobación indica un problema de ruta de E/S. Para determinar la causa, es necesario investigar el hardware, los controladores de firmware, el BIOS, los controladores de filtro (por ejemplo, software antivirus) y otros componentes de ruta de E/S.

  • TORN_PAGE_DETECTION

    Guarda una pauta específica de 2 bits por cada sector de 512 bytes en la página de base de datos de 8 kilobytes (KB) y la almacena en el encabezado de página de la base de datos al escribir la página en el disco. Si la página se lee desde el disco, los bits rasgados almacenados en el encabezado de página se comparan con la información del sector de la página real.

    Los valores no coincidentes indican que solamente se ha escrito en el disco una parte de la página. En esta situación, se genera el mensaje de error 824 (indica un error de página rasgada) tanto para el registro de errores de SQL Server como para el registro de eventos de Windows. Las páginas rasgadas se suelen detectar mediante la recuperación de la base de datos si se trata realmente de la escritura incompleta de una página. No obstante, otros errores de ruta de E/S pueden generar una página rasgada en cualquier momento.

  • Ninguno

    Las escrituras de página de base de datos no generan un valor CHECKSUM ni TORN_PAGE_DETECTION. SQL Server no comprueba una suma de comprobación ni una página rasgada durante una lectura incluso si hay un valor CHECKSUM o TORN_PAGE_DETECTION presente en el encabezado de página.

Tenga en cuenta los siguientes puntos importantes cuando utilice la opción PAGE_VERIFY:

  • El valor predeterminado es CHECKSUM.

  • Si una base de datos de usuario o del sistema se actualiza a SQL Server 2005 (9.x) o una versión posterior, no cambia el valor de PAGE_VERIFY (NONE o TORN_PAGE_DETECTION). Se recomienda cambiar a CHECKSUM.

    Nota:

    En las versiones anteriores de SQL Server, la opción de base de datos PAGE_VERIFY se establece en NONE para la base de datos tempdb y no se puede modificar. A partir de SQL Server 2008 (10.0.x), el valor predeterminado para la base de datos tempdb es CHECKSUM para las nuevas instalaciones de SQL Server. Al actualizar una instalación de SQL Server, el valor predeterminado sigue siendo NONE. La opción se puede modificar. Se recomienda usar CHECKSUM para la base de datos tempdb.

  • TORN_PAGE_DETECTION puede usar menos recursos, pero proporciona un subconjunto mínimo de la protección CHECKSUM.

  • PAGE_VERIFY se puede configurar sin dejar la base de datos sin conexión, ni bloquearla ni impedir la simultaneidad en ella.

  • CHECKSUM y TORN_PAGE_DETECTION se excluyen mutuamente. No se pueden habilitar ambas opciones al mismo tiempo.

Si se detecta un error de suma de comprobación o de página rasgada, puede realizar una recuperación mediante la restauración de los datos o una regeneración del índice, si el error se limita únicamente a las páginas de índice. Si detecta un error de suma de comprobación, ejecute DBCC CHECKDB para determinar el tipo de página o páginas de base de datos afectadas. Para más información sobre las opciones de restauración, consulte Argumentos RESTORE. Aunque la restauración de los datos resuelve el problema de daños en los datos, la causa principal (por ejemplo, error de hardware del disco) debe diagnosticarse y corregirse lo antes posible para evitar errores continuos.

SQL Server reintenta cualquier lectura que produzca un error de suma de comprobación, página rasgada u otro error de E/S cuatro veces. Si la lectura se realiza correctamente en cualquiera de los reintentos, se escribe un mensaje en el registro de errores. El comando que desencadenó la lectura continúa. El comando produce un error en el mensaje de error 824 si se produce un error en los reintentos.

Para más información sobre los mensajes de error 823, 824 y 825, vea:

La configuración actual de esta opción se puede determinar si examina la columna page_verify_option de la vista de catálogo sys.databases o la propiedad IsTornPageDetectionEnabled de la función DATABASEPROPERTYEX.

<remote_data_archive_option> ::=

Se aplica a: SQL Server (a partir de SQL Server 2016 (13.x))

Habilita o deshabilita Stretch Database para la base de datos. Para obtener más información, vea Stretch Database.

Importante

Stretch Database está en desuso en SQL Server 2022 (16.x) y Azure SQL Database. Esta característica se quitará en una versión futura del motor de base de datos. Evite utilizar esta característica en nuevos trabajos de desarrollo y tenga previsto modificar las aplicaciones que actualmente la utilizan.

REMOTE_DATA_ARCHIVE = { ON ( SERVER = <server_name>, { CREDENTIAL = <db_scoped_credential_name> | FEDERATED_SERVICE_ACCOUNT = ON | OFF } ) | OFF

  • ACTIVAR

    Habilita Stretch Database para la base de datos. Para más información, incluidos los requisitos previos adicionales, vea Enable Stretch Database for a database (Habilitar Stretch Database para una base de datos).

    Necesita el permiso db_owner para habilitar Stretch Database para una tabla. Necesita los permisos db_owner y CONTROL DATABASE para habilitar Stretch Database para una tabla.

    • SERVER = <server_name>

      Especifica la dirección del servidor de Azure. Incluye la parte .database.windows.net del nombre. Por ejemplo, MyStretchDatabaseServer.database.windows.net.

    • CREDENTIAL = <db_scoped_credential_name>

      Especifica la credencial de ámbito de base de datos que la instancia de SQL Server usa para conectarse al servidor de Azure. Asegúrese de que la credencial existe antes de ejecutar este comando. Para más información, consulte CREATE DATABASE SCOPED CREDENTIAL.

    • FEDERATED_SERVICE_ACCOUNT = { ON | OFF }

      Puede usar una cuenta de servicio federado para que el servidor SQL Server local se comunique con el servidor remoto de Azure cuando se cumplan estas condiciones.

      • La cuenta de servicio con la que se está ejecutando la instancia de SQL Server es una cuenta de dominio.
      • La cuenta de dominio pertenece a un dominio cuya instancia de Active Directory está federada con el identificador de Microsoft Entra.
      • El servidor remoto de Azure está configurado para admitir la autenticación de Microsoft Entra.
      • La cuenta de servicio con la que se ejecuta la instancia de SQL Server debe configurarse como una cuenta dbmanager o sysadmin en el servidor remoto de Azure.

      Si indica que la cuenta de servicio federada está activada, no podrá especificar además el argumento CREDENTIAL. Proporcione el argumento CREDENTIAL si especifica OFF.

  • Apagado

    Deshabilita Stretch Database para la base de datos. Para obtener más información, vea Deshabilitar Stretch Database y recuperar datos remotos.

    Solo puede deshabilitar Stretch Database para una base de datos una vez que la base de datos ya no contenga ninguna tabla que esté habilitada para Stretch Database. Después de deshabilitar Stretch Database, la migración de datos se detiene. Además, los resultados de la consulta ya no incluyen los resultados de las tablas remotas.

    Al deshabilitar Stretch Database, no se quita la base de datos remota. Para eliminar la base de datos remota, colóquela mediante Azure Portal.

PERSISTENT_LOG_BUFFER

se aplica a: SQL Server 2017 (14.x) y versiones posteriores.

Cuando se especifica esta opción, el búfer del registro de transacciones se crea en un volumen que se encuentra en un dispositivo de disco respaldado por memoria de clase de almacenamiento (NVDIMM-N almacenamiento no volátil), también conocido como búfer de registro persistente. Para obtener más información, consulte aceleración de latencia de confirmación de transacciones mediante de memoria de clase de almacenamiento y Agregar búfer de registro persistente a una base de datos.

<service_broker_option> ::=

Se aplica a: SQL Server

Controla las siguientes opciones de Service Broker: habilita o deshabilita la entrega de mensajes, establece un nuevo identificador de Service Broker o establece prioridades de conversación en ON u OFF.

ENABLE_BROKER

Indica que se habilite Service Broker para la base de datos especificada. Se inicia la entrega de mensajes y la marca is_broker_enabled se establece en true en la vista de catálogo sys.databases. La base de datos conserva el identificador de Service Broker existente. Service Broker no puede habilitarse mientras la base de datos sea la entidad de seguridad en una configuración de creación de reflejo de la base de datos.

Nota:

ENABLE_BROKER requiere un bloqueo exclusivo de base de datos. Si otras sesiones tienen recursos bloqueados en la base de datos, ENABLE_BROKER espera hasta que las otras sesiones liberen sus bloqueos. Para habilitar Service Broker en una base de datos de usuario, asegúrese de que ninguna otra sesión esté utilizando la base de datos antes de ejecutar la instrucción ALTER DATABASE SET ENABLE_BROKER, por ejemplo, colocando la base de datos en modo de usuario único. Para habilitar Service Broker en la base de datos msdb, detenga en primer lugar el Agente SQL Server para que Service Broker pueda obtener el bloqueo necesario.

DISABLE_BROKER

Indica que se deshabilite Service Broker para la base de datos especificada. Se detiene la entrega de mensajes y la marca is_broker_enabled se establece en false en la vista de catálogo sys.databases. La base de datos conserva el identificador de Service Broker existente.

NEW_BROKER

Especifica que la base de datos debe recibir un identificador de agente nuevo. La base de datos actúa como un nuevo agente de servicio. Como tal, todas las conversaciones existentes en la base de datos se quitan inmediatamente sin generar mensajes de finalización de diálogo. Cualquier ruta que haga referencia al identificador de Service Broker anterior se debe volver a crear con el nuevo identificador.

ERROR_BROKER_CONVERSATIONS

Especifica que la entrega de mensajes de Service Broker está habilitada. Este valor conserva el identificador de Service Broker existente para la base de datos. Service Broker finaliza todas las conversaciones de la base de datos con un error. Este valor permite que las aplicaciones realicen una ejecución regular de las conversaciones existentes.

HONOR_BROKER_PRIORITY { ON | OFF }

  • ACTIVAR

    Las operaciones de envío tienen en cuenta los niveles de prioridad asignados a las conversaciones. Los mensajes de las conversaciones que tienen niveles de prioridad altos se envían antes que los que tienen asignados niveles de prioridad bajos.

  • Apagado

    Las operaciones de envío se ejecutan como si todas las conversaciones tuvieran el nivel de prioridad predeterminado.

Los cambios de la opción HONOR_BROKER_PRIORITY tienen efecto inmediato para los diálogos nuevos o los que no tiene ningún mensaje en espera de ser enviado. Los diálogos con mensajes que se van a enviar cuando se ejecuta ALTER DATABASE no seleccionan la nueva configuración hasta que se envían algunos de los mensajes del cuadro de diálogo. La cantidad de tiempo que transcurre hasta que se inicien todos los diálogos con el nuevo valor puede variar considerablemente.

El valor actual de esta propiedad se notifica en la columna is_broker_priority_honored de la vista de catálogo sys.databases.

<snapshot_option> ::=

Calcula el nivel de aislamiento de la transacción.

ALLOW_SNAPSHOT_ISOLATION { ON | OFF }

  • ACTIVAR

    Habilita la opción de instantánea en el nivel de base de datos. Cuando se habilita, las instrucciones DML inician la generación de versiones de fila aunque ninguna transacción utilice el aislamiento de instantánea. Una vez habilitada esta opción, las transacciones pueden especificar el nivel de aislamiento de transacción SNAPSHOT. Si se ejecuta una transacción en el nivel de aislamiento SNAPSHOT, todas las instrucciones verán una instantánea de los datos tal como estaban al inicio de la transacción. Si una transacción ejecutada en el nivel de aislamiento SNAPSHOT tiene acceso a los datos de varias bases de datos, ALLOW_SNAPSHOT_ISOLATION debe establecerse en ON en todas las bases de datos o cada instrucción de la transacción debe utilizar sugerencias de bloqueo en cualquier referencia de una cláusula FROM a una tabla de una base de datos donde ALLOW_SNAPSHOT_ISOLATION sea OFF.

  • Apagado

    Desactiva la opción de instantánea en el nivel de base de datos. Las transacciones no pueden especificar el nivel de aislamiento de la transacción SNAPSHOT.

Si se establece ALLOW_SNAPSHOT_ISOLATION en un estado nuevo (de ON a OFF o de OFF a ON), ALTER DATABASE no devuelve el control al autor de la llamada hasta confirmar todas las transacciones existentes de la base de datos. Si la base de datos ya se encuentra en el estado especificado en la instrucción ALTER DATABASE, se devuelve de inmediato el control al autor de la llamada. Use sys.dm_tran_active_snapshot_database_transactions para determinar si hay transacciones de ejecución prolongada si la instrucción ALTER DATABASE no devuelve resultados rápidamente. Si se cancela la instrucción ALTER DATABASE, la base de datos permanece en el estado en que estaba al iniciar ALTER DATABASE. La vista de catálogo sys.databases indica el estado de las transacciones de aislamiento de instantáneas en la base de datos. Si snapshot_isolation_state_desc = IN_TRANSITION_TO_ON, el comando ALTER DATABASE ... ALLOW_SNAPSHOT_ISOLATION OFF pausa seis segundos y vuelve a intentar la operación.

No puede cambiar el estado de ALLOW_SNAPSHOT_ISOLATION si la base de datos está establecida en OFFLINE.

Si establece ALLOW_SNAPSHOT_ISOLATION en una base de datos de READ_ONLY, la configuración se mantiene si la base de datos se establece más adelante en READ_WRITE.

Puede cambiar la configuración de ALLOW_SNAPSHOT_ISOLATION para las bases de datos master, model, msdb y tempdb. La configuración se mantiene cada vez que la instancia de Motor de base de datos se detiene y se reinicia si cambia la configuración para tempdb. Si cambia la configuración para model, dicha configuración se convierte en predeterminada para todas las nuevas bases de datos creadas, excepto para tempdb.

La opción es ON de forma predeterminada para las bases de datos master y msdb.

El valor actual de esta opción se puede determinar mediante el examen de la columna snapshot_isolation_state en la vista de catálogo sys.databases.

READ_COMMITTED_SNAPSHOT { ON | OFF }

  • ACTIVAR

    Habilita la opción de instantánea de lectura confirmada en el nivel de base de datos. Cuando se habilita, las instrucciones DML inician la generación de versiones de fila aunque ninguna transacción utilice el aislamiento de instantánea. Una vez habilitada esta opción, las transacciones que especifican el nivel de aislamiento de lectura confirmada usan versiones de fila en lugar de bloqueos. Todas las instrucciones ven una instantánea de los datos tal y como existen al inicio de la instrucción si una transacción se ejecuta en el nivel de aislamiento READ COMMITTED.

  • Apagado

    Desactiva la opción de instantánea de lectura confirmada en el nivel de base de datos. Las transacciones que especifican el nivel de aislamiento READ COMMITTED utilizan el bloqueo.

Para establecer READ_COMMITTED_SNAPSHOT en ON u OFF, no puede haber ninguna conexión activa a la base de datos, excepto la que ejecuta el comando ALTER DATABASE. Sin embargo, no es necesario que la base de datos esté en modo de usuario único. No puede cambiar el estado de esta opción si la base de datos está establecida en OFFLINE.

Si establece READ_COMMITTED_SNAPSHOT en una base de datos de READ_ONLY, la configuración se mantiene cuando la base de datos se establece más adelante en READ_WRITE.

READ_COMMITTED_SNAPSHOT no se puede establecer en ON para las bases de datos del sistema master, tempdb o msdb. Si cambia la configuración para model, dicha configuración se convierte en predeterminada para todas las nuevas bases de datos creadas, excepto para tempdb.

El valor actual de esta opción se puede determinar mediante el examen de la columna is_read_committed_snapshot_on en la vista de catálogo sys.databases.

Advertencia

Cuando se crea una tabla con DURABILITY = SCHEMA_ONLY, y posteriormente se cambia READ_COMMITTED_SNAPSHOT mediante ALTER DATABASE, se pierden los datos de la tabla.

MEMORY_OPTIMIZED_ELEVATE_TO_SNAPSHOT { ON | OFF }

Se aplica a: SQL Server (a partir de SQL Server 2014 (12.x))

  • ACTIVAR

    Cuando el nivel de aislamiento de transacción se establece en uno inferior a SNAPSHOT, todas las operaciones interpretadas de Transact-SQL en las tablas optimizadas para memoria se ejecutan con aislamiento SNAPSHOT. Los ejemplos de los niveles de aislamiento inferiores a la instantánea son READ COMMITTED o READ UNCOMMITTED. Estas operaciones se ejecutan si el nivel de aislamiento de transacción se establece explícitamente en el nivel de sesión o el valor predeterminado se utiliza de forma implícita.

  • Apagado

    No eleva el nivel de aislamiento de transacción para las operaciones interpretadas de Transact-SQL en las tablas optimizadas para memoria.

No puede cambiar el estado de MEMORY_OPTIMIZED_ELEVATE_TO_SNAPSHOT si la base de datos está establecida en OFFLINE.

De forma predeterminada, la opción está desactivada.

El valor actual de esta opción se puede determinar mediante el examen de la columna is_memory_optimized_elevate_to_snapshot_on en la vista de catálogo sys.databases.

<sql_option> ::=

Controla las opciones de cumplimiento con ANSI en el nivel de base de datos.

ANSI_NULL_DEFAULT { ON | OFF }

Determina el valor predeterminado, NULL o NOT NULL, de una columna o del tipo definido por el usuario CLR para los que no se ha definido la nulabilidad explícitamente en las instrucciones CREATE TABLE o ALTER TABLE. Las columnas definidas con restricciones siguen las reglas de restricción que pueda ser esta configuración.

  • ACTIVAR

    El valor predeterminado de una columna sin definir es NULL.

  • Apagado

    El valor predeterminado de una columna sin definir es NOT NULL.

La configuración del nivel de conexión, establecida mediante la instrucción SET, invalida la configuración predeterminada del nivel de base de datos para ANSI_NULL_DEFAULT. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión mediante el establecimiento de ANSI_NULL_DEFAULT en ON para la sesión. Los clientes ejecutan la instrucción cuando se conecta a una instancia de SQL Server. Para más información, consulte SET ANSI_NULL_DFLT_ON.

Para la compatibilidad con ANSI, si se establece la opción de base de datos ANSI_NULL_DEFAULT en ON, el valor predeterminado cambia a NULL.

Para determinar el estado de esta opción, examine la columna is_ansi_null_default_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAnsiNullDefault de la función DATABASEPROPERTYEX.

ANSI_NULLS { ON | OFF }

  • ACTIVAR

    Todas las comparaciones con un valor NULL se evalúan como UNKNOWN.

  • Apagado

    Las comparaciones de valores no Unicode con un valor NULL se evalúan como TRUE si ambos valores son NULL.

Importante

En una versión futura de SQL Server, ANSI_NULLS siempre estará ON y cualquier aplicación que establezca explícitamente la opción en OFF producirá un error. Evite utilizar esta característica en nuevos trabajos de desarrollo y tenga previsto modificar las aplicaciones que actualmente la utilizan.

La configuración del nivel de conexión establecida mediante la instrucción SET invalida la configuración predeterminada de la base de datos para ANSI_NULLS. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión mediante el establecimiento de ANSI_NULLS en ON para la sesión. Los clientes ejecutan la instrucción cuando se conecta a una instancia de SQL Server. Para más información, consulte SET ANSI_NULLS.

Importante

El valor de SET ANSI_NULLS también debe estar en ON al crear o realizar cambios en los índices en columnas calculadas o vistas indizadas.

Para determinar el estado de esta opción, examine la columna is_ansi_nulls_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAnsiNullsEnabled de la función DATABASEPROPERTYEX.

ANSI_PADDING { ON | OFF }

  • ACTIVAR

    Las cadenas se rellenan a la misma longitud antes de la conversión. También se rellenan hasta la misma longitud antes de la inserción en un tipo de datos varchar o nvarchar.

  • Apagado

    Inserta espacios en blanco finales en los valores de caracteres en las columnas varchar o nvarchar. También deja los ceros a la derecha en los valores binarios insertados en columnas varbinary. Los valores no se rellenan hasta completar la longitud de la columna.

    Si se especifica OFF, esta opción solamente afecta a la definición de las columnas nuevas.

Importante

En una versión futura de SQL Server, ANSI_PADDING siempre estará en ON y cualquier aplicación que establezca explícitamente la opción en OFF producirá un error. Evite utilizar esta característica en nuevos trabajos de desarrollo y tenga previsto modificar las aplicaciones que actualmente la utilizan. Se recomienda establecer siempre ANSI_PADDING en ON. ANSI_PADDING también debe estar en ON al crear o tratar índices en columnas calculadas o vistas indizadas.

char(n) y binary(n) las columnas que admiten valores NULL se rellenan hasta la longitud de la columna cuando ANSI_PADDING se establece en ON. Los ceros y los espacios en blanco finales se recortan si ANSI_PADDING es OFF. Las columnas char(n) y binary(n) que no permiten valores NULL siempre se rellenan hasta completar la longitud de la columna.

La configuración del nivel de conexión establecida mediante la instrucción SET invalida la configuración predeterminada del nivel de base de datos para ANSI_PADDING. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión mediante el establecimiento de ANSI_PADDING en ON para la sesión. Los clientes ejecutan la instrucción cuando se conecta a una instancia de SQL Server. Para más información, consulte SET ANSI_PADDING.

Para determinar el estado de esta opción, examine la columna is_ansi_padding_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAnsiPaddingEnabled de la función DATABASEPROPERTYEX.

ANSI_WARNINGS { ON | OFF }

  • ACTIVAR

    Se emiten errores o advertencias si se dan condiciones tales como la división por cero. También se emiten errores y advertencias cuando aparecen valores null en funciones de agregado.

  • Apagado

    No se genera ninguna advertencia ni se devuelven valores NULL si se producen condiciones como la división por cero.

Importante

El valor de SET ANSI_WARNINGS debe ser ON al crear o realizar cambios en los índices en columnas calculadas o vistas indizadas.

La configuración del nivel de conexión establecida mediante la instrucción SET invalida la configuración predeterminada de la base de datos para ANSI_WARNINGS. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión mediante el establecimiento de ANSI_WARNINGS en ON para la sesión. Los clientes ejecutan la instrucción cuando se conecta a una instancia de SQL Server. Para más información, consulte SET ANSI_WARNINGS.

Para determinar el estado de esta opción, examine la columna is_ansi_warnings_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAnsiWarningsEnabled de la función DATABASEPROPERTYEX.

ARITHABORT { ON | OFF }

  • ACTIVAR

    Se finaliza una consulta cuando se produce un error de desbordamiento o de división por cero durante su ejecución.

  • Apagado

    Aparece un mensaje de advertencia cuando se produce uno de estos errores. La consulta, el proceso por lotes o la transacción continúa procesándose como si no se hubiera producido ningún error aunque se muestre una advertencia.

Importante

El valor de SET ARITHABORT debe ser ON al crear o realizar cambios en los índices en columnas calculadas o vistas indizadas.

Para determinar el estado de esta opción, examine la columna is_arithabort_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsArithmeticAbortEnabled de la función DATABASEPROPERTYEX.

COMPATIBILITY_LEVEL = { 160 | 150 | 140 | 130 | 120 | 110 | 100 }

Para obtener más información, consulte nivel de compatibilidad de ALTER DATABASE.

CONCAT_NULL_YIELDS_NULL { ON | OFF }

  • ACTIVAR

    El resultado de una operación de concatenación es NULL si alguno de los operandos es NULL. Por ejemplo, la concatenación de la cadena de caracteres "Esto es" y NULL devuelve el valor NULL, en lugar del valor "Esto es".

  • Apagado

    El valor NULL se trata como una cadena de caracteres vacía.

Importante

El valor de CONCAT_NULL_YIELDS_NULL también debe ser ON al crear o realizar cambios en los índices en columnas calculadas o vistas indizadas.

En versiones futuras de SQL Server, CONCAT_NULL_YIELDS_NULL siempre será ON y cualquier aplicación que establezca de forma explícita la opción en OFF generará un error. Evite utilizar esta característica en nuevos trabajos de desarrollo y tenga previsto modificar las aplicaciones que actualmente la utilizan.

La configuración del nivel de conexión establecida mediante la instrucción SET invalida la configuración predeterminada de la base de datos para CONCAT_NULL_YIELDS_NULL. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión y establecen CONCAT_NULL_YIELDS_NULL en ON para la sesión al realizar la conexión con una instancia de SQL Server. Para más información, consulte SET CONCAT_NULL_YIELDS_NULL.

Para determinar el estado de esta opción, examine la columna is_concat_null_yields_null_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsNullConcat de la función DATABASEPROPERTYEX.

NUMERIC_ROUNDABORT { ON | OFF }

  • ACTIVAR

    Se genera un error cuando se produce una pérdida de precisión en una expresión.

  • Apagado

    Las pérdidas de precisión no generan un mensaje de error y el resultado se redondea con la precisión de la columna o variable que lo almacena.

    Importante

    El valor de NUMERIC_ROUNDABORT debe ser OFF al crear o realizar cambios en índices de columnas calculadas o vistas indizadas.

Puede determinar el estado de esta opción en la columna is_numeric_roundabort_on de la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsNumericRoundAbortEnabled de la función DATABASEPROPERTYEX.

QUOTED_IDENTIFIER { ON | OFF }

  • ACTIVAR

    Las comillas dobles se pueden usar para identificadores delimitados.

    Todas las cadenas delimitadas por comillas dobles se interpretan como identificadores de objetos. Los identificadores entre comillas no tienen que adaptarse a las reglas de Transact-SQL para identificadores. Pueden ser palabras clave e incluir caracteres que no se permiten en los identificadores de Transact-SQL. Si una comilla doble (") forma parte del identificador, puede representarse entre dos comillas dobles ("").

  • Apagado

    Los identificadores no se pueden incluir entre comillas y deben seguir todas las reglas de Transact-SQL para los identificadores. Los literales se pueden delimitar con comillas simples o dobles.

SQL Server también permite delimitar los identificadores con corchetes ([ y ]). Los identificadores entre corchetes pueden usarse siempre, independientemente del valor de QUOTED_IDENTIFIER. Para obtener más información, consulte Identificadores de base de datos.

Al crear una tabla, la opción QUOTED IDENTIFIER siempre se almacena como ON en los metadatos de la tabla. La opción se almacena incluso si está establecida en OFF al crear la tabla.

La configuración en el nivel de conexión establecida mediante la instrucción SET invalida la configuración predeterminada de la base de datos para QUOTED_IDENTIFIER. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión estableciendo QUOTED_IDENTIFIER en ON. Los clientes ejecutan la instrucción cuando se conecta a una instancia de SQL Server. Para más información, consulte SET QUOTED_IDENTIFIER.

Para determinar el estado de esta opción, examine la columna is_quoted_identifier_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsQuotedIdentifiersEnabled de la función DATABASEPROPERTYEX.

RECURSIVE_TRIGGERS { ON | OFF }

  • ACTIVAR

    Se permite la activación recursiva de desencadenadores AFTER.

  • Apagado

    Para determinar el estado de esta opción, examine la columna is_recursive_triggers_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsRecursiveTriggersEnabled de la función DATABASEPROPERTYEX.

Nota:

La recursividad directa solo se evita cuando RECURSIVE_TRIGGERS se establece en OFF. Para deshabilitar la recursividad indirecta, también debe establecer la opción de servidor desencadenadores anidados en 0.

Para determinar el estado de esta opción, examine la columna is_recursive_triggers_onde la vista de catálogo sys.databases o la propiedad IsRecursiveTriggersEnabled de la función DATABASEPROPERTYEX.

<suspend_for_snapshot_backup> ::=

Se aplica a: SQL Server (a partir de SQL Server 2022 [16.x])

Suspende las bases de datos para la copia de seguridad de instantáneas. Puede definir un grupo de una o varias bases de datos. Puede designar el modo de solo copia.

SET SUSPEND_FOR_SNAPSHOT_BACKUP = { ON | OFF }

Suspende o anula las suspensiones de las bases de datos. Valor predeterminado: OFF.

MODE = COPY_ONLY

Opcional. Usa el modo COPY_ONLY.

<target_recovery_time_option> ::=

Se aplica a: SQL Server (a partir de SQL Server 2012 (11.x))

Especifica la frecuencia de puntos de comprobación indirectos por base de datos. A partir de SQL Server 2016 (13.x), el valor predeterminado para las nuevas bases de datos es 1 minuto, que indica que la base de datos usa puntos de control indirectos. Para las versiones anteriores, el valor predeterminado es 0, que indica que la base de datos usa puntos de control automáticos, cuya frecuencia depende de la configuración del intervalo de recuperación de la instancia del servidor. Microsoft recomienda un minuto para la mayoría de los sistemas.

TARGET_RECOVERY_TIME = target_recovery_time { SECONDS | MINUTES }

  • target_recovery_time

    Especifica el límite máximo de tiempo para recuperar la base de datos especificada en caso de bloqueo. target_recovery_time es del tipo int.

  • SECONDS

    Indica que target_recovery_time se expresa como el número de segundos.

  • MINUTES

    Indica que target_recovery_time se expresa como el número de minutos.

Para obtener más información sobre los puntos de control indirectos, consulte Puntos de control de base de datos.

WITH <termination> ::=

Especifica el momento en que se revierten las transacciones incompletas cuando la base de datos pasa de un estado a otro. Si se omite la cláusula de terminación, la instrucción ALTER DATABASE espera indefinidamente a que se produzca un bloqueo en la base de datos. Solamente se puede especificar una cláusula de terminación y debe seguir a las cláusulas SET.

Nota:

No todas las opciones de base de datos usan la cláusula WITH <termination>. Para más información, consulte la tabla en "Opciones de configuración de la sección "Comentarios" de este artículo.

  • ROLLBACK AFTER integer [SECONDS] | ROLLBACK IMMEDIATE

    Especifica si la operación de reversión se ejecuta transcurrido un número de segundos determinado o de forma inmediata.

  • NO_WAIT

    Especifica que se produce un error en la solicitud si el estado de la base de datos o el cambio de opción solicitados no se pueden completar inmediatamente. Completarse inmediatamente significa que no se espera a que las transacciones se confirmen o reviertan por su cuenta.

Opciones de Set

Para recuperar la configuración actual de las opciones de base de datos, use la vista de catálogo sys.databases o DATABASEPROPERTYEX.

Una vez configurada una opción de la base de datos, la nueva configuración surte efecto de inmediato.

Puede cambiar los valores predeterminados de cualquiera de las opciones de las bases de datos recién creadas. Para ello, cambie la opción adecuada de base de datos en la base de datos model.

No todas las opciones de base de datos usan la cláusula WITH <termination> ni se pueden especificar en combinación con otras opciones. En la siguiente tabla se incluyen estas opciones, su estado y el estado de terminación.

Categoría de opciones Se puede especificar con otras opciones Puede usar la cláusula WITH <termination>
<db_state_option>
<db_user_access_option>
<db_update_option>
<delayed_durability_option>
<external_access_option> No
<cursor_option> No
<auto_option> No
<sql_option> No
<recovery_option> No
<target_recovery_time_option> No
<database_mirroring_option> No No
ALLOW_SNAPSHOT_ISOLATION No No
READ_COMMITTED_SNAPSHOT No
MEMORY_OPTIMIZED_ELEVATE_TO_SNAPSHOT
<service_broker_option> No
DATE_CORRELATION_OPTIMIZATION
<parameterization_option>
<change_tracking_option>
<db_encryption_option> No
<accelerated_database_recovery>

La memoria caché de planes para la instancia de SQL Server se borra si se establece alguna de las opciones siguientes:

OFFLINE

ONLINE

MODIFY_NAME

COLLATE

READ_ONLY

READ_WRITE

MODIFY FILEGROUP DEFAULT

MODIFY FILEGROUP READ_WRITE

MODIFY FILEGROUP READ_ONLY

La caché de planes también se vacía en los escenarios siguientes.

  • Una base de datos tiene la opción de base de datos AUTO_CLOSE establecida en ON. Cuando ninguna conexión de usuario hace referencia a la base de datos ni la usa, la tarea de segundo plano intenta cerrar la base de datos y apagarla de modo automático.
  • Ejecuta varias consultas con una base de datos que tiene opciones predeterminadas. Después, la base de datos se quita.
  • Se quita una instantánea de base de datos para una base de datos de origen.
  • Volvió a generar correctamente el registro de transacciones para una base de datos.
  • Restaura una copia de seguridad de una base de datos
  • Separa una base de datos.

Al borrar la memoria caché de planes, se provoca una nueva compilación de todos los planes de ejecución posteriores y puede ocasionar una disminución repentina y temporal del rendimiento de las consultas. Para cada almacén de caché borrado de la caché de planes, el registro de errores de SQL Server contiene el siguiente mensaje informativo: SQL Server has encountered %d occurrence(s) of cachestore flush for the '%s' cachestore (part of plan cache) due to some database maintenance or reconfigure operations. Este mensaje se registra cada cinco minutos siempre que se vacíe la memoria caché dentro de ese intervalo de tiempo.

Ejemplos

A. Configuración de opciones en una base de datos

En el siguiente ejemplo se establece el modelo de recuperación y las opciones de comprobación de páginas de datos para la base de datos de ejemplo AdventureWorks2022 .

USE master;
GO
ALTER DATABASE [database_name]
SET RECOVERY FULL PAGE_VERIFY CHECKSUM;
GO

B. Establecimiento de la base de datos en READ_ONLY

El cambio del estado de una base de datos o un grupo de archivos a READ_ONLY o READ_WRITE requiere el acceso exclusivo a la base de datos. En el siguiente ejemplo la base de datos se establece en el modo SINGLE_USER para obtener acceso exclusivo. A continuación, el ejemplo establece el estado de la base de datos AdventureWorks2022 en READ_ONLY y devuelve el acceso a la base de datos a todos los usuarios.

Nota:

En este ejemplo se utiliza la opción de terminación WITH ROLLBACK IMMEDIATE en la primera instrucción ALTER DATABASE . Todas las transacciones incompletas se revierten y cualquier otra conexión a la base de datos AdventureWorks2022 se desconecta inmediatamente.

USE master;
GO
ALTER DATABASE [database_name]
SET SINGLE_USER
WITH ROLLBACK IMMEDIATE;
GO
ALTER DATABASE [database_name]
SET READ_ONLY
GO
ALTER DATABASE [database_name]
SET MULTI_USER;
GO

C. Habilitación del aislamiento de instantáneas en una base de datos

En el siguiente ejemplo se habilita la opción del marco de aislamiento de instantánea para la base de datos AdventureWorks2022 .

USE [database_name];
USE master;
GO
ALTER DATABASE [database_name]
SET ALLOW_SNAPSHOT_ISOLATION ON;
GO
-- Check the state of the snapshot_isolation_framework
-- in the database.
SELECT name, snapshot_isolation_state,
    snapshot_isolation_state_desc AS description
FROM sys.databases
WHERE name = N'[database_name]';
GO

El conjunto de resultados muestra que el marco de aislamiento de instantánea está habilitado.

name snapshot_isolation_state description
[database_name] 1 ACTIVAR

D. Habilitación, modificación o deshabilitación del seguimiento de cambios

En el ejemplo siguiente se habilita el seguimiento de cambios para la base de datos AdventureWorks2022 y se establece el período de retención en 2 días.

ALTER DATABASE [database_name]
SET CHANGE_TRACKING = ON
(AUTO_CLEANUP = ON, CHANGE_RETENTION = 2 DAYS);

En el ejemplo siguiente se muestra cómo cambiar el período de retención a 3 días.

ALTER DATABASE [database_name]
SET CHANGE_TRACKING (CHANGE_RETENTION = 3 DAYS);

En el ejemplo siguiente se muestra cómo deshabilitar el seguimiento de cambios para la base de datos AdventureWorks2022 .

ALTER DATABASE [database_name]
SET CHANGE_TRACKING = OFF;

E. Habilitación del Almacén de consultas

Se aplica a: SQL Server (a partir de SQL Server 2016 (13.x))

En el ejemplo siguiente se habilita el Almacén de consultas y configura sus parámetros.

ALTER DATABASE [database_name]
SET QUERY_STORE = ON
    (
      OPERATION_MODE = READ_WRITE,
      CLEANUP_POLICY = ( STALE_QUERY_THRESHOLD_DAYS = 90 ),
      DATA_FLUSH_INTERVAL_SECONDS = 900,
      QUERY_CAPTURE_MODE = AUTO,
      MAX_STORAGE_SIZE_MB = 1024,
      INTERVAL_LENGTH_MINUTES = 60
    );

F. Habilitación del Almacén de consultas con estadísticas de espera

Se aplica a: SQL Server (a partir de SQL Server 2017 (14.x))

En el ejemplo siguiente se habilita el Almacén de consultas y configura sus parámetros.

ALTER DATABASE [database_name]
SET QUERY_STORE = ON
    (
      OPERATION_MODE = READ_WRITE,
      CLEANUP_POLICY = ( STALE_QUERY_THRESHOLD_DAYS = 90 ),
      DATA_FLUSH_INTERVAL_SECONDS = 900,
      MAX_STORAGE_SIZE_MB = 1024,
      INTERVAL_LENGTH_MINUTES = 60,
      SIZE_BASED_CLEANUP_MODE = AUTO,
      MAX_PLANS_PER_QUERY = 200,
      WAIT_STATS_CAPTURE_MODE = ON,
    );

G. Habilitación del Almacén de consultas con las opciones de directiva de captura personalizadas

Se aplica a: SQL Server (a partir de SQL Server 2019 (15.x))

En el ejemplo siguiente se habilita el Almacén de consultas y configura sus parámetros.

ALTER DATABASE [database_name]
SET QUERY_STORE = ON
    (
      OPERATION_MODE = READ_WRITE,
      CLEANUP_POLICY = ( STALE_QUERY_THRESHOLD_DAYS = 90 ),
      DATA_FLUSH_INTERVAL_SECONDS = 900,
      MAX_STORAGE_SIZE_MB = 1024,
      INTERVAL_LENGTH_MINUTES = 60,
      SIZE_BASED_CLEANUP_MODE = AUTO,
      MAX_PLANS_PER_QUERY = 200,
      WAIT_STATS_CAPTURE_MODE = ON,
      QUERY_CAPTURE_MODE = CUSTOM,
      QUERY_CAPTURE_POLICY = (
        STALE_CAPTURE_POLICY_THRESHOLD = 24 HOURS,
        EXECUTION_COUNT = 30,
        TOTAL_COMPILE_CPU_TIME_MS = 1000,
        TOTAL_EXECUTION_CPU_TIME_MS = 100
      )
    );

* SQL Database *  

 

SQL Database

Los niveles de compatibilidad son opciones de SET, pero se describen en nivel de compatibilidad de ALTER DATABASE.

Nota:

Es posible configurar muchas opciones SET de la base de datos para la sesión actual mediante Instrucciones SET, aunque generalmente las configuran las aplicaciones al realizar la conexión. Las opciones SET de nivel de sesión reemplazan a los valores ALTER DATABASE SET. Las opciones de base de datos descritas en las secciones siguientes son valores que se pueden establecer para sesiones que no proporcionan de forma explícita otros valores de opciones SET.

Sintaxis

ALTER DATABASE { database_name | Current }
SET
{
    <option_spec> [ ,...n ] [ WITH <termination> ]
}
;

<option_spec> ::=
{
    <auto_option>
  | <automatic_tuning_option>
  | <change_tracking_option>
  | <cursor_option>
  | <db_encryption_option>
  | <db_update_option>
  | <db_user_access_option>
  | <delayed_durability_option>
  | <parameterization_option>
  | <query_store_options>
  | <snapshot_option>
  | <sql_option>
  | <target_recovery_time_option>
  | <termination>
  | <temporal_history_retention>
}
;

<auto_option> ::=
{
    AUTO_CREATE_STATISTICS { OFF | ON [ ( INCREMENTAL = { ON | OFF } ) ] }
  | AUTO_SHRINK { ON | OFF }
  | AUTO_UPDATE_STATISTICS { ON | OFF }
  | AUTO_UPDATE_STATISTICS_ASYNC { ON | OFF }
}

<automatic_tuning_option> ::=
{
    AUTOMATIC_TUNING = { AUTO | INHERIT | CUSTOM }
  | AUTOMATIC_TUNING ( CREATE_INDEX = { DEFAULT | ON | OFF } )
  | AUTOMATIC_TUNING ( DROP_INDEX = { DEFAULT | ON | OFF } )
  | AUTOMATIC_TUNING ( FORCE_LAST_GOOD_PLAN = { DEFAULT | ON | OFF } )
}

<change_tracking_option> ::=
{
    CHANGE_TRACKING
    {
        = OFF
      | = ON [ ( <change_tracking_option_list > [,...n] ) ]
      | ( <change_tracking_option_list> [,...n] )
    }
}

<change_tracking_option_list> ::=
   {
       AUTO_CLEANUP = { ON | OFF }
     | CHANGE_RETENTION = retention_period { DAYS | HOURS | MINUTES }
   }

<cursor_option> ::=
{
    CURSOR_CLOSE_ON_COMMIT { ON | OFF }
}

<db_encryption_option> ::=
  ENCRYPTION { ON | OFF }

<db_update_option> ::=
  { READ_ONLY | READ_WRITE }

<db_user_access_option> ::=
  { RESTRICTED_USER | MULTI_USER }

<delayed_durability_option> ::= DELAYED_DURABILITY = { DISABLED | ALLOWED | FORCED }

<parameterization_option> ::=
  PARAMETERIZATION { SIMPLE | FORCED }

<query_store_options> ::=
{
  QUERY_STORE
  {
      = OFF
    | = ON [ ( <query_store_option_list> [,... n] ) ]
    | ( < query_store_option_list> [,... n] )
    | CLEAR [ ALL ]
  }
}

<query_store_option_list> ::=
{
  OPERATION_MODE = { READ_WRITE | READ_ONLY }
  | CLEANUP_POLICY = ( STALE_QUERY_THRESHOLD_DAYS = number )
  | DATA_FLUSH_INTERVAL_SECONDS = number
  | MAX_STORAGE_SIZE_MB = number
  | INTERVAL_LENGTH_MINUTES = number
  | SIZE_BASED_CLEANUP_MODE = { AUTO | OFF }
  | QUERY_CAPTURE_MODE = { ALL | AUTO | CUSTOM | NONE }
  | MAX_PLANS_PER_QUERY = number
  | WAIT_STATS_CAPTURE_MODE = { ON | OFF }
  | QUERY_CAPTURE_POLICY = ( <query_capture_policy_option_list> [,...n] )
}

<query_capture_policy_option_list> :: =
{
    STALE_CAPTURE_POLICY_THRESHOLD = number { DAYS | HOURS }
    | EXECUTION_COUNT = number
    | TOTAL_COMPILE_CPU_TIME_MS = number
    | TOTAL_EXECUTION_CPU_TIME_MS = number
}

<snapshot_option> ::=
{
    ALLOW_SNAPSHOT_ISOLATION { ON | OFF }
  | READ_COMMITTED_SNAPSHOT { ON | OFF }
  | MEMORY_OPTIMIZED_ELEVATE_TO_SNAPSHOT { ON | OFF }
}
<sql_option> ::=
{
    ANSI_NULL_DEFAULT { ON | OFF }
  | ANSI_NULLS { ON | OFF }
  | ANSI_PADDING { ON | OFF }
  | ANSI_WARNINGS { ON | OFF }
  | ARITHABORT { ON | OFF }
  | COMPATIBILITY_LEVEL = { 160 | 150 | 140 | 130 | 120 | 110 | 100 }
  | CONCAT_NULL_YIELDS_NULL { ON | OFF }
  | NUMERIC_ROUNDABORT { ON | OFF }
  | QUOTED_IDENTIFIER { ON | OFF }
  | RECURSIVE_TRIGGERS { ON | OFF }
}

<termination>::=
{
    ROLLBACK AFTER integer [ SECONDS ]
  | ROLLBACK IMMEDIATE
  | NO_WAIT
}

<temporal_history_retention>::=TEMPORAL_HISTORY_RETENTION { ON | OFF }

Argumentos

database_name

Nombre de la base de datos que se va a modificar.

  • CURRENT

    CURRENT realiza la acción en la base de datos actual. CURRENT no se admite para todas las opciones en todos los contextos. Si CURRENT produce un error, proporcione el nombre de la base de datos.

<auto_option> ::=

Controla las opciones automáticas.

AUTO_CREATE_STATISTICS { ON | OFF }

  • ACTIVAR

    El optimizador de consultas crea estadísticas en columnas únicas de los predicados de consulta, según sea necesario, para mejorar los planes de consulta y el rendimiento de las consultas. Estas estadísticas de columna única se crean cuando el optimizador de consultas las compila. Las estadísticas de columna única solamente se crean en las columnas que ya no son la primera columna de un objeto de estadísticas existente.

    El valor predeterminado es ON. Recomendamos utilizar la configuración predeterminada para la mayoría de las bases de datos.

  • Apagado

    El optimizador de consultas no crea las estadísticas en columnas únicas de los predicados de consulta cuando compila las consultas. Establecer esta opción en OFF puede producir planes de consulta poco óptimos y un rendimiento degradado de las consultas.

Para determinar el estado de esta opción, examine la columna is_auto_create_stats_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAutoCreateStatistics de la función DATABASEPROPERTYEX.

Para más información, vea la sección "Opciones de estadísticas" en Estadísticas.

INCREMENTAL = ON | OFF

Establezca AUTO_CREATE_STATISTICS en ON y establezca INCREMENTAL en ON. Esta configuración crea automáticamente estadísticas como incrementales siempre que se admitan estadísticas incrementales. El valor predeterminado es OFF. Para más información, consulte CREATE STATISTICS.

AUTO_SHRINK { ON | OFF }

  • ACTIVAR

    Los archivos de la base de datos se pueden reducir periódicamente. A menos que tenga un requisito específico, no establezca la opción AUTO_SHRINK base de datos en ACTIVADO. Para más información, consulte Shrink a Database.

Pueden reducirse automáticamente los archivos de datos y los archivos de registro. AUTO_SHRINK reduce el tamaño del registro de transacciones solo si establece la base de datos en el modelo de recuperación SIMPLE o si realiza una copia de seguridad del registro. Cuando se establece en OFF, los archivos de la base de datos no se reducen de forma automática durante las comprobaciones periódicas del espacio no utilizado.

La opción AUTO_SHRINK reduce los archivos cuando no se utiliza más de un 25% del espacio del archivo. La opción hace que el archivo se reduzca a uno de dos tamaños. Se reduce al que sea más grande de los siguientes:

  • El tamaño donde el 25 por ciento del archivo es espacio no utilizado
  • El tamaño del archivo cuando se creó

No puede reducir una base de datos de solo lectura.

  • Apagado

    Los archivos de base de datos no se reducen automáticamente durante las comprobaciones periódicas de espacio sin usar.

Para determinar el estado de esta opción, examine la columna is_auto_shrink_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAutoShrink de la función DATABASEPROPERTYEX.

Nota:

La opción AUTO_SHRINK no está disponible en una base de datos independiente.

AUTO_UPDATE_STATISTICS { ON | OFF }

  • ACTIVAR

    Especifica que el optimizador de consultas actualiza las estadísticas cuando las usa una consulta y puedan estar obsoletas. Las estadísticas se vuelven obsoletas después de que operaciones de inserción, actualización, eliminación o combinación cambien la distribución de los datos en la tabla o la vista indizada. Para determinar cuándo las estadísticas pueden quedar obsoletas, el optimizador de consultas cuenta el número de modificaciones de datos desde la actualización más reciente de las estadísticas y compara el número de modificaciones con un umbral. El umbral se basa en el número de filas de la tabla o la vista indizada.

    El optimizador de consultas comprueba si hay estadísticas obsoletas antes de compilar una consulta y ejecuta un plan de consulta almacenado en caché. El optimizador de consultas usa las columnas, tablas y vistas indexadas del predicado de consulta para determinar qué estadísticas podrían estar obsoletas. El optimizador de consultas determina esta información antes de compilar una consulta. Antes de ejecutar un plan de consulta almacenado en caché, Motor de base de datos comprueba que el plan de consulta haga referencia a las estadísticas actualizadas.

    La opción AUTO_UPDATE_STATISTICS se aplica a las estadísticas creadas para índices y columnas únicas de los predicados de consulta, así como a las estadísticas creadas con la instrucción CREATE STATISTICS. Esta opción también se aplica a las estadísticas filtradas.

    El valor predeterminado es ON. Recomendamos utilizar la configuración predeterminada para la mayoría de las bases de datos.

    Utilice la opción AUTO_UPDATE_STATISTICS_ASYNC para especificar si las estadísticas se actualizan sincrónica o asincrónicamente.

  • Apagado

    Especifica que el optimizador de consultas no actualiza las estadísticas cuando una consulta las usa. El optimizador de consultas tampoco actualiza las estadísticas cuando podrían estar obsoletas. Establecer esta opción en OFF puede producir planes de consulta poco óptimos y un rendimiento degradado de las consultas.

    Para determinar el estado de esta opción, examine la columna is_auto_update_stats_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAutoUpdateStatistics de la función DATABASEPROPERTYEX.

    Para más información, vea la sección "Opciones de estadísticas" en Estadísticas.

AUTO_UPDATE_STATISTICS_ASYNC { ON | OFF }

  • ACTIVAR

    Especifica que las actualizaciones de las estadísticas para la opción AUTO_UPDATE_STATISTICS son asincrónicas. El optimizador de consultas no espera a que finalicen las actualizaciones de las estadísticas para compilar las consultas.

    La configuración de esta opción en ON no surte efecto a menos que AUTO_UPDATE_STATISTICS se establezca en ON.

    De forma predeterminada, la opción AUTO_UPDATE_STATISTICS_ASYNC se establece en OFF y el optimizador de consultas actualiza las estadísticas de manera sincrónica.

  • Apagado

    Especifica que las actualizaciones de las estadísticas para la opción AUTO_UPDATE_STATISTICS son sincrónicas. El optimizador de consultas espera a que finalicen las actualizaciones de las estadísticas para compilar las consultas.

    La configuración de esta opción en OFF no surte efecto a menos que AUTO_UPDATE_STATISTICS esté configurado en ON.

Para determinar el estado de esta opción, examine la columna is_auto_update_stats_async_on en la vista de catálogo sys.databases.

Para más información sobre cuándo usar las actualizaciones de estadísticas sincrónicas o asincrónicas, vea la sección "Opciones de estadísticas" en Estadísticas.

<automatic_tuning_option> ::=

Controla las opciones automáticas para el ajuste automático. Puede ver las opciones de la siguiente configuración en Azure Portal o a través de T-SQL en la vista sys.database_automatic_tuning_options.

AUTOMATIC_TUNING = { AUTO | INHERIT | CUSTOM }

  • AUTO

    Al establecer el valor ajuste automático en AUTO, se aplican los valores predeterminados de configuración de Azure para el ajuste automático. En Azure Portal, esto refleja la opción "Heredar de: valores predeterminados de Azure".

  • INHERIT

    Si se usa el valor INHERIT, se hereda la configuración predeterminada del servidor primario. En Azure Portal, esto refleja la opción de "Heredar de: servidor". Esto es especialmente útil si quiere personalizar la configuración de ajuste automático en un servidor primario y que todas las bases de datos del servidor hereden esta configuración personalizada. Para que la herencia funcione, las tres opciones de ajuste individuales FORCE_LAST_GOOD_PLAN, CREATE_INDEX y DROP_INDEX deben establecerse en DEFAULT en las bases de datos.

  • CUSTOM

    Con el valor CUSTOM, debe configurar de forma personalizada cada una de las opciones de ajuste automático disponibles en las bases de datos. En Azure Portal, esto refleja la opción "Heredar de: no heredar".

CREATE_INDEX = { DEFAULT | ON | OFF }

Habilita o deshabilita la opción CREATE_INDEX de administración de índices automática del ajuste automático. Puede ver el estado de esta opción en Azure Portal o mediante T-SQL en la vista sys.database_automatic_tuning_options.

  • DEFAULT

    Hereda la configuración predeterminada del servidor. En este caso, las opciones para habilitar o deshabilitar las características de Ajuste automático individuales están definidas en el nivel de servidor.

  • ACTIVAR

    Cuando se habilita, se generan automáticamente los índices que faltan en una base de datos. Después de la creación del índice, se comprueban las mejoras de rendimiento de la carga de trabajo. Cuando el índice creado ya no proporciona ventajas en el rendimiento de la carga de trabajo, se revierte automáticamente. Los índices creados automáticamente se marcan como un índice generado por el sistema.

  • Apagado

    No genera automáticamente índices que faltan en la base de datos.

DROP_INDEX = { DEFAULT | ON | OFF }

Habilita o deshabilita la opción DROP_INDEX de administración de índices automática del ajuste automático. Puede ver el estado de esta opción en Azure Portal o mediante T-SQL en la vista sys.database_automatic_tuning_options.

  • DEFAULT

    Hereda la configuración predeterminada del servidor. En este caso, las opciones para habilitar o deshabilitar las características de Ajuste automático individuales están definidas en el nivel de servidor.

  • ACTIVAR

    Quita de forma automática los índices duplicados o que ya no son útiles para la carga de trabajo de rendimiento.

  • Apagado

    No quita automáticamente índices que faltan en la base de datos.

FORCE_LAST_GOOD_PLAN = { DEFAULT | ON | OFF }

Habilita o deshabilita la opción FORCE_LAST_GOOD_PLAN de corrección de planes automática del ajuste automático. Puede ver el estado de esta opción en Azure Portal o mediante T-SQL en la vista sys.database_automatic_tuning_options.

  • DEFAULT

    Hereda la configuración predeterminada del servidor. En este caso, las opciones para habilitar o deshabilitar las características de Ajuste automático individuales están definidas en el nivel de servidor. Este es el valor predeterminado. El valor predeterminado para los nuevos servidores de Azure SQL Server es ON, lo que significa que, de forma predeterminada, las nuevas bases de datos heredan la configuración de ON.

  • ACTIVAR

    Motor de base de datos fuerza automáticamente el último buen plan conocido en las consultas de Transact-SQL, donde el nuevo plan de consulta provoca regresiones de rendimiento. El parámetro Motor de base de datos supervisa continuamente el rendimiento de la consulta Transact-SQL con el plan forzado. Si hay mejoras de rendimiento, el motor de base de datos sigue usando el último plan correcto conocido. Si no se detectan mejoras de rendimiento, el motor de base de datos genera un nuevo plan de consulta. Se produce un error en la instrucción si el Almacén de consultas no está habilitado o no está en modo de lectura y escritura.

  • Apagado

    Motor de base de datos informa de posibles regresiones de rendimiento de consultas provocadas por cambios del plan de consulta en la vista sys.dm_db_tuning_recommendations, Sin embargo, estas recomendaciones no se aplican automáticamente. Para supervisar las recomendaciones activas y corregir los problemas identificados, los usuarios pueden aplicar los scripts de Transact-SQL que se muestran en la vista.

<change_tracking_option> ::=

Controla las opciones de seguimiento de cambios. Puede habilitar el seguimiento de cambios, establecer y cambiar opciones, y deshabilitar el seguimiento de cambios. Para obtener ejemplos, vea la sección Ejemplos más adelante en este artículo.

  • ACTIVAR

    Habilita el seguimiento de cambios para la base de datos. Si habilita el seguimiento de cambios, también puede establecer las opciones AUTO CLEANUP y CHANGE RETENTION.

    • AUTO_CLEANUP = { ON | OFF }

      • ACTIVAR

        La información sobre el seguimiento de cambios se quita de forma automática después del período de retención especificado.

      • Apagado

        Los datos del seguimiento de cambios no se quitan de la base de datos.

    • CHANGE_RETENTION = período_de_retención { DAYS | HOURS | MINUTES }

      Especifica el período mínimo para mantener la información del seguimiento de cambios en la base de datos. Los datos solamente se quitan cuando el valor AUTO_CLEANUP es ON.

      retention_period es un entero que especifica el componente numérico del período de retención.

      El período de retención predeterminado es de 2 días. El período de retención mínimo es de 1 minuto. El tipo de retención predeterminado es DAYS.

  • Apagado

    Deshabilita el seguimiento de cambios para la base de datos. Deshabilite el seguimiento de cambios en todas las tablas para poder deshabilitarlo en la base de datos.

<cursor_option> ::=

Controla las opciones del cursor.

CURSOR_CLOSE_ON_COMMIT { ON | OFF }

  • ACTIVAR

    Todos los cursores abiertos cuando confirma o deshace una transacción se cierran.

  • Apagado

    Los cursores permanecen abiertos cuando se confirma una transacción; Revertir una transacción cierra los cursores excepto los que se definen como INSENSITIVE o STATIC.

La configuración del nivel de conexión, establecida mediante la instrucción SET, invalida la configuración predeterminada de la base de datos para CURSOR_CLOSE_ON_COMMIT. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión que establece CURSOR_CLOSE_ON_COMMIT en OFF para la sesión. Los clientes ejecutan la instrucción cuando se conecta a una instancia de SQL Server. Para más información, consulte SET CURSOR_CLOSE_ON_COMMIT.

Para determinar el estado de esta opción, examine la columna is_cursor_close_on_commit_onde la vista de catálogo sys.databases o la propiedad IsCloseCursorsOnCommitEnabled de la función DATABASEPROPERTYEX. El cursor se desasigna implícitamente solamente cuando se realiza la desconexión. Para más información, consulte DECLARE CURSOR.

<db_encryption_option> ::=

Controla el estado del cifrado de la base de datos.

ENCRYPTION { ON | OFF }

Establece que se cifre (ON) o no se cifre (OFF) la base de datos. Para más información sobre el cifrado de bases de datos, consulte cifrado de datos transparente (TDE)y Cifrado de datos transparente para Azure SQL Database, Azure SQL Managed Instance y Azure Synapse Analytics.

Cuando el cifrado está habilitado en el nivel de base de datos, todos los grupos de archivos se cifran. Los nuevos grupos de archivos heredan la propiedad cifrada. Si algún grupo de archivos de la base de datos se establece en READ ONLY, se produce un error en la operación de cifrado de la base de datos.

Puede ver el estado del cifrado de la base de datos mediante la vista de administración dinámica sys.dm_database_encryption_keys.

<db_update_option> ::=

Controla si se permiten las actualizaciones en la base de datos.

  • READ_ONLY

    Los usuarios pueden leer datos de la base de datos, pero no pueden modificarlos.

    Nota:

    Para mejorar el rendimiento de las consultas, actualice las estadísticas antes de establecer una base de datos en READ_ONLY. Si se necesitan estadísticas adicionales después de establecer una base de datos en READ_ONLY, el motor de base de datos crea estadísticas en tempdb. Para más información sobre las estadísticas para una base de datos de solo lectura, vea Utilizar las estadísticas para mejorar el rendimiento de las consultas.

  • READ_WRITE

    La base de datos está disponible para operaciones de lectura y escritura.

Para cambiar este estado, debe tener acceso exclusivo a la base de datos. Para obtener más información, vea la cláusula SINGLE_USER.

Nota:

En las bases de datos federadas de Azure SQL Database, SET { READ_ONLY | READ_WRITE } está deshabilitado.

<db_user_access_option> ::=

Controla el acceso del usuario a la base de datos.

  • RESTRICTED_USER

    Solo permite a los miembros del rol fijo de base de datos db_owner y de los roles fijos de servidor dbcreator y sysadmin conectarse a la base de datos, pero no limita la cantidad de miembros. Todas las conexiones a la base de datos se desconectan en el margen de tiempo especificado por la cláusula de terminación de la instrucción ALTER DATABASE. Una vez que la base de datos ha cambiado al estado RESTRICTED_USER, se rechazan los intentos de conexión por parte de usuarios no cualificados. En Azure SQL Database, debe ejecutarse desde dentro de la base de datos de usuario. En la base de datos de master, es posible que encuentre un mensaje de error Msg 42008, Level 16, State 3, Line 1 ODBC error: State: 28000: Error: 18456 Message:'[Microsoft][ODBC Driver 17 for SQL Server][SQL Server]Login failed for user '##MS_InstanceCertificate##'.'.

  • MULTI_USER

    Todos los usuarios que tengan los permisos correspondientes pueden conectarse a la base de datos. Para determinar el estado de esta opción, examine la columna user_accessde la vista de catálogo sys.databases o la propiedad UserAccess de la función DATABASEPROPERTYEX. En Azure SQL Database, debe ejecutarse desde dentro de la base de datos de usuario. En la base de datos de master, es posible que encuentre un mensaje de error Msg 42008, Level 16, State 3, Line 1 ODBC error: State: 28000: Error: 18456 Message:'[Microsoft][ODBC Driver 17 for SQL Server][SQL Server]Login failed for user '##MS_InstanceCertificate##'.'.

<delayed_durability_option> ::=

Controla si las transacciones se confirman con perdurabilidad total o diferida.

  • DISABLED

    Todas las transacciones tras SET DISABLED son totalmente perdurables. Se omiten las opciones de perdurabilidad que se establecen en un bloque ATOMIC o en una instrucción de confirmación.

  • ALLOWED

    Todas las transacciones tras SET ALLOWED son totalmente perdurables o de perdurabilidad diferida, dependiendo de la opción de perdurabilidad establecida en el bloque ATOMIC o la instrucción de confirmación.

  • FORCED

    Todas las transacciones tras SET FORCED son de perdurabilidad diferida. Se omiten las opciones de perdurabilidad que se establecen en un bloque ATOMIC o en una instrucción de confirmación.

<PARAMETERIZATION_option> ::=

Controla la opción de parametrización.

PARAMETERIZATION { SIMPLE | FORCED }

  • SIMPLE

    Las consultas incluyen parámetros en función del comportamiento predeterminado de la base de datos.

  • FORCED

    SQL Server incluye parámetros para todas las consultas de la base de datos.

El valor actual de esta opción se puede determinar mediante el examen de la columna is_parameterization_forced en la vista de catálogo sys.databases.

<query_store_options> ::=

  • ON | OFF | CLEAR [ ALL ]

    Controla si el almacén de consultas está habilitado en esta base de datos y también controla la eliminación del contenido del almacén de consultas.

    • ACTIVAR

      Habilita el Almacén de consultas. ON es el valor predeterminado.

    • Apagado

      Deshabilita el Almacén de consultas.

      Nota:

      El Almacén de consultas no se puede deshabilitar en la base de datos única de Azure SQL Database ni Grupo elástico. Al ejecutar ALTER DATABASE [database] SET QUERY_STORE = OFF devuelve la advertencia 'QUERY_STORE=OFF' is not supported in this version of SQL Server..

    • CLEAR

      Quita el contenido del Almacén de consultas.

OPERATION_MODE

Describe el modo de operación del Almacén de consultas. Los valores válidos son READ_ONLY y READ_WRITE. En el modo READ_WRITE, el Almacén de consultas recopila y continúa el plan de consultas y la información de estadística del tiempo de ejecución. En el modo READ_ONLY, la información se puede leer del almacén de consultas, pero no se agrega información nueva. Si se ha agotado el espacio máximo asignado del Almacén de consultas, el Almacén de consultas cambia el modo de operación a READ_ONLY.

CLEANUP_POLICY

Describe la directiva de retención de datos del Almacén de consultas. STALE_QUERY_THRESHOLD_DAYS determina el número de días durante los que se conserva la información de una consulta en el Almacén de consultas. STALE_QUERY_THRESHOLD_DAYS es de tipo bigint. El valor predeterminado es 30. En la edición SQL Database Basic, el valor predeterminado es 7 días.

DATA_FLUSH_INTERVAL_SECONDS

Determina la frecuencia con la que los datos escritos en el Almacén de consultas se conservan en el disco. Para optimizar el rendimiento, los datos recopilados por el Almacén de consultas se escriben de manera asincrónica en el disco. La frecuencia con la que se produce esta transferencia asincrónica se configura mediante el argumento DATA_FLUSH_INTERVAL_SECONDS. DATA_FLUSH_INTERVAL_SECONDS es de tipo bigint. El valor predeterminado es 900 (15 minutos).

MAX_STORAGE_SIZE_MB

Determina el espacio asignado al Almacén de consultas. MAX_STORAGE_SIZE_MB es de tipo bigint.

Nota:

En Azure SQL Database, el valor predeterminado MAX_STORAGE_SIZE_MB difiere según el nivel de servicio, como se indica a continuación: Premium, Crítico para la empresa e Hiperescala: 1024 MB; Estándar y De uso general: 100 MB; Básico: 10 MB El valor máximo permitido MAX_STORAGE_SIZE_MB es de 10 240 MB.

Nota:

El límite MAX_STORAGE_SIZE_MB no se aplica de forma estricta. El tamaño de almacenamiento solo se comprueba cuando el almacén de consultas escribe datos en el disco. Este intervalo se establece mediante la opción DATA_FLUSH_INTERVAL_SECONDS o la opción de diálogo Intervalo de vaciado de datos del Almacén de consultas de Management Studio. El valor predeterminado de intervalo es 900 segundos (o 15 minutos). Si el Almacén de consultas ha infringido el límite de MAX_STORAGE_SIZE_MB entre las comprobaciones de tamaño de almacenamiento, realiza la transición al modo de solo lectura. Si SIZE_BASED_CLEANUP_MODE está habilitado, también se desencadena el mecanismo de limpieza para aplicar el límite de MAX_STORAGE_SIZE_MB. Una vez que se ha borrado suficiente espacio, el modo almacén de consultas cambia automáticamente a lectura y escritura.

Importante

Si cree que la captura de carga de trabajo necesita más de 10 GB de espacio en disco, probablemente debería replantear y optimizar la carga de trabajo para reutilizar los planes de consulta (por ejemplo, mediante parametrización forzadao ajustar las configuraciones del Almacén de consultas. A partir de SQL Server 2019 (15.x) y en Azure SQL Database, puede establecer QUERY_CAPTURE_MODE en PERSONALIZADO para obtener un control adicional sobre la directiva de captura de consultas.

INTERVAL_LENGTH_MINUTES

Determina el intervalo de tiempo en el que se agregan los datos de estadísticas de ejecución en tiempo de ejecución al Almacén de consultas. Para optimizar el uso del espacio, se agregan las estadísticas de ejecución en tiempo de ejecución en el almacén de estadísticas de tiempo de ejecución en una ventana de tiempo fijo. Esta ventana de tiempo fijo se configura con el argumento INTERVAL_LENGTH_MINUTES. INTERVAL_LENGTH_MINUTES es de tipo bigint. El valor predeterminado es 60.

SIZE_BASED_CLEANUP_MODE = { AUTO | OFF }

Controla si la limpieza se activa automáticamente cuando la cantidad total de datos se acerca al tamaño máximo.

  • Apagado

    La limpieza basada en tamaño no se activa automáticamente.

  • AUTO

    La limpieza basada en tamaño se activa automáticamente cuando el tamaño del disco alcanza los 90% de max_storage_size_mb. La limpieza según el tamaño quita primero las consultas menos caras y más antiguas. Se detiene aproximadamente en el 80 % de max_storage_size_mb. Es el valor de configuración predeterminado.

SIZE_BASED_CLEANUP_MODE es de tipo nvarchar.

QUERY_CAPTURE_MODE { ALL | AUTO | CUSTOM | NONE }

Designa el modo de captura de consulta que está activo. Cada modo define directivas de captura de consulta específicas.

Nota:

Los cursores, las consultas dentro de procedimientos almacenados y las consultas compiladas de forma nativa siempre se capturan cuando el modo de captura de consulta se establece en ALL, AUTO o CUSTOM.

  • ALL

    Captura todas las consultas.

  • AUTO

    Captura consultas pertinentes en función del consumo de recursos y el recuento de ejecuciones. Es el valor de configuración predeterminado para Azure SQL Database.

  • Ninguno

    Detiene la captura de nuevas consultas. El Almacén de consultas sigue recopilando estadísticas de compilación y tiempo de ejecución para las consultas que ya se capturaron. Use esta configuración con precaución, ya que es posible que no capture consultas importantes.

  • CUSTOM

    Permite controlar las opciones de QUERY_CAPTURE_POLICY.

QUERY_CAPTURE_MODE es de tipo nvarchar.

max_plans_per_query

Define el número máximo de planes que se tienen para cada consulta. MAX_PLANS_PER_QUERY es del tipo int. El valor predeterminado es 200.

WAIT_STATS_CAPTURE_MODE { ON | OFF }

Controla si las estadísticas de espera se capturan por consulta.

  • ACTIVAR

    Se captura información de estadísticas de espera por consulta. Este es el valor de configuración predeterminado.

  • Apagado

    No se captura la información de estadísticas de espera por consulta.

<query_capture_policy_option_list> :: =

Controla las opciones de directiva de captura de Almacén de consultas. Excepto en STALE_CAPTURE_POLICY_THRESHOLD, estas opciones definen las condiciones OR que se tienen que dar para que las consultas se capturen en el valor definido en el umbral de la directiva de capturas obsoletas.

STALE_CAPTURE_POLICY_THRESHOLD = entero { DAYS | HOURS }

Define el período de intervalo de evaluación para determinar si se debe capturar una consulta. El valor predeterminado es de 1 día y puede establecerse de 1 hora a 7 días. number es del tipo int.

EXECUTION_COUNT = entero

Define el número de veces que se ejecuta una consulta durante el período de evaluación. El valor predeterminado es 30, lo que significa que, para el valor predeterminado del umbral de la directiva de capturas obsoletas, una consulta se tendrá que ejecutar al menos 30 veces en un día para que se conserve en el almacén de consultas. EXECUTION_COUNT es del tipo int.

TOTAL_COMPILE_CPU_TIME_MS = entero

Define el tiempo total de CPU de compilación transcurrido que usa una consulta durante el período de evaluación. El valor predeterminado es 1000, lo que significa que, para el valor predeterminado del umbral de la directiva de capturas obsoletas, una consulta tendrá que invertir un total de al menos un segundo de tiempo de CPU durante la compilación de consulta en un día para conservarse en el Almacén de consultas. TOTAL_COMPILE_CPU_TIME_MS es del tipo int.

TOTAL_EXECUTION_CPU_TIME_MS = entero

Define el tiempo de ejecución total de CPU transcurrido que ha utilizado una consulta durante el período de evaluación. El valor predeterminado es 100, lo que significa que, para el valor predeterminado del umbral de la directiva de capturas obsoletas, una consulta tendrá que invertir un total de al menos 100 ms de tiempo de CPU durante la ejecución en un día para que se conserve en el almacén de consultas. TOTAL_EXECUTION_CPU_TIME_MS es del tipo int.

<snapshot_option> ::=

Determina el nivel de aislamiento de transacción.

ALLOW_SNAPSHOT_ISOLATION { ON | OFF }

  • ACTIVAR

    Habilita la opción de instantánea en el nivel de base de datos. Cuando se habilita, las instrucciones DML inician la generación de versiones de fila aunque ninguna transacción utilice el aislamiento de instantánea. Una vez habilitada esta opción, las transacciones pueden especificar el nivel de aislamiento de transacción SNAPSHOT. Si se ejecuta una transacción en el nivel de aislamiento SNAPSHOT, todas las instrucciones verán una instantánea de los datos tal como estaban al inicio de la transacción. Si una transacción ejecutada en el nivel de aislamiento SNAPSHOT tiene acceso a los datos de varias bases de datos, ALLOW_SNAPSHOT_ISOLATION debe establecerse en ON en todas las bases de datos o cada instrucción de la transacción debe utilizar sugerencias de bloqueo en cualquier referencia de una cláusula FROM a una tabla de una base de datos donde ALLOW_SNAPSHOT_ISOLATION sea OFF.

  • Apagado

    Desactiva la opción de instantánea en el nivel de base de datos. Las transacciones no pueden especificar el nivel de aislamiento de la transacción SNAPSHOT.

Si se establece ALLOW_SNAPSHOT_ISOLATION en un estado nuevo (de ON a OFF o de OFF a ON), ALTER DATABASE no devuelve el control al autor de la llamada hasta confirmar todas las transacciones existentes de la base de datos. Si la base de datos ya se encuentra en el estado especificado en la instrucción ALTER DATABASE, se devuelve de inmediato el control al autor de la llamada. Use sys.dm_tran_active_snapshot_database_transactions para determinar si hay transacciones de ejecución prolongada si la instrucción ALTER DATABASE no devuelve resultados rápidamente. Si se cancela la instrucción ALTER DATABASE, la base de datos permanece en el estado en que estaba al iniciar ALTER DATABASE. La vista de catálogo sys.databases indica el estado de las transacciones de aislamiento de instantáneas en la base de datos. Si snapshot_isolation_state_desc = IN_TRANSITION_TO_ON, la instrucción ALTER DATABASE .... ALLOW_SNAPSHOT_ISOLATION OFF pausa seis segundos y vuelve a intentar la operación.

No puede cambiar el estado de ALLOW_SNAPSHOT_ISOLATION si la base de datos está establecida en OFFLINE.

Si establece ALLOW_SNAPSHOT_ISOLATION en una base de datos de READ_ONLY, la configuración se mantiene si la base de datos se establece más adelante en READ_WRITE.

El valor actual de esta opción se puede determinar mediante el examen de la columna snapshot_isolation_state en la vista de catálogo sys.databases.

READ_COMMITTED_SNAPSHOT { ON | OFF }

  • ACTIVAR

    Habilita la opción de instantánea de lectura confirmada en el nivel de base de datos. Cuando se habilita, las instrucciones DML inician la generación de versiones de fila aunque ninguna transacción utilice el aislamiento de instantánea. Una vez habilitada esta opción, las transacciones que especifican el nivel de aislamiento READ COMMITTED usan versiones de fila en lugar de bloqueos. Todas las instrucciones ven una instantánea de los datos tal y como existen al inicio de la instrucción si una transacción se ejecuta en el nivel de aislamiento READ COMMITTED.

  • Apagado

    Desactiva la opción de instantánea de lectura confirmada en el nivel de base de datos. Las transacciones que especifican el nivel de aislamiento READ COMMITTED utilizan el bloqueo.

Para establecer READ_COMMITTED_SNAPSHOT en ON u OFF, no puede haber ninguna conexión activa a la base de datos, excepto la que ejecuta el comando ALTER DATABASE. Sin embargo, no es necesario que la base de datos esté en modo de usuario único. No puede cambiar el estado de esta opción si la base de datos está establecida en OFFLINE.

Si establece READ_COMMITTED_SNAPSHOT en una base de datos de READ_ONLY, la configuración se mantiene cuando la base de datos se establece más adelante en READ_WRITE.

READ_COMMITTED_SNAPSHOT no se puede establecer en ON para las bases de datos del sistema master, tempdb o msdb. Si cambia la configuración para model, dicha configuración se convierte en predeterminada para todas las nuevas bases de datos creadas, excepto para tempdb.

El valor actual de esta opción se puede determinar mediante el examen de la columna is_read_committed_snapshot_on en la vista de catálogo sys.databases.

Advertencia

Cuando se crea una tabla con DURABILITY = SCHEMA_ONLYy READ_COMMITTED_SNAPSHOT se cambia posteriormente mediante ALTER DATABASE, se pierden los datos de la tabla.

Sugerencia

En Azure SQL Database, el comando ALTER DATABASE para activar o desactivar READ_COMMITTED_SNAPSHOT para una base de datos debe ejecutarse en la base de datosmaster.

MEMORY_OPTIMIZED_ELEVATE_TO_SNAPSHOT { ON | OFF }

  • ACTIVAR

    Cuando el nivel de aislamiento de transacción se establece en uno inferior a SNAPSHOT, todas las operaciones interpretadas de Transact-SQL en las tablas optimizadas para memoria se ejecutan con aislamiento SNAPSHOT. Los ejemplos de los niveles de aislamiento inferiores a la instantánea son READ COMMITTED o READ UNCOMMITTED. Estas operaciones se ejecutan si el nivel de aislamiento de transacción se establece explícitamente en el nivel de sesión o el valor predeterminado se utiliza de forma implícita.

  • Apagado

    No eleva el nivel de aislamiento de transacción para las operaciones interpretadas de Transact-SQL en las tablas optimizadas para memoria.

No puede cambiar el estado de MEMORY_OPTIMIZED_ELEVATE_TO_SNAPSHOT si la base de datos está establecida en OFFLINE.

El valor predeterminado es OFF.

El valor actual de esta opción se puede determinar mediante el examen de la columna is_memory_optimized_elevate_to_snapshot_on en la vista de catálogo sys.databases.

<sql_option> ::=

Controla las opciones de cumplimiento con ANSI en el nivel de base de datos.

ANSI_NULL_DEFAULT { ON | OFF }

Determina el valor predeterminado, NULL o NOT NULL, de una columna o del tipo definido por el usuario CLR para los que no se ha definido la nulabilidad explícitamente en las instrucciones CREATE TABLE o ALTER TABLE. Las columnas definidas con restricciones siguen las reglas de restricción que pueda ser esta configuración.

  • ACTIVAR

    El valor predeterminado es NULL.

  • Apagado

    El valor predeterminado es NOT NULL.

La configuración del nivel de conexión, establecida mediante la instrucción SET, invalida la configuración predeterminada del nivel de base de datos para ANSI_NULL_DEFAULT. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión mediante el establecimiento de ANSI_NULL_DEFAULT en ON para la sesión. Los clientes ejecutan la instrucción cuando se conecta a una instancia de SQL Server. Para más información, consulte SET ANSI_NULL_DFLT_ON.

Para la compatibilidad con ANSI, si se establece la opción de base de datos ANSI_NULL_DEFAULT en ON, el valor predeterminado cambia a NULL.

Para determinar el estado de esta opción, examine la columna is_ansi_null_default_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAnsiNullDefault de la función DATABASEPROPERTYEX.

ANSI_NULLS { ON | OFF }

  • ACTIVAR

    Todas las comparaciones con un valor NULL se evalúan como UNKNOWN.

  • Apagado

    Las comparaciones de valores no Unicode con un valor NULL se evalúan como TRUE si ambos valores son NULL.

Importante

En una versión futura de SQL Server, ANSI_NULLS siempre estará ON y cualquier aplicación que establezca explícitamente la opción en OFF producirá un error. Evite utilizar esta característica en nuevos trabajos de desarrollo y tenga previsto modificar las aplicaciones que actualmente la utilizan.

La configuración del nivel de conexión establecida mediante la instrucción SET invalida la configuración predeterminada de la base de datos para ANSI_NULLS. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión mediante el establecimiento de ANSI_NULLS en ON para la sesión. Los clientes ejecutan la instrucción cuando se conecta a una instancia de SQL Server. Para más información, consulte SET ANSI_NULLS.

Nota:

El valor de SET ANSI_NULLS también debe estar en ON al crear o realizar cambios en los índices en columnas calculadas o vistas indizadas.

Para determinar el estado de esta opción, examine la columna is_ansi_nulls_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAnsiNullsEnabled de la función DATABASEPROPERTYEX.

ANSI_PADDING { ON | OFF }

  • ACTIVAR

    Las cadenas se rellenan a la misma longitud antes de la conversión. También se rellenan hasta la misma longitud antes de la inserción en un tipo de datos varchar o nvarchar.

  • Apagado

    Inserta espacios en blanco finales en los valores de caracteres en las columnas varchar o nvarchar. También deja los ceros a la derecha en los valores binarios insertados en columnas varbinary. Los valores no se rellenan hasta completar la longitud de la columna.

    Si se especifica OFF, esta opción solamente afecta a la definición de las columnas nuevas.

Importante

En una versión futura de SQL Server, ANSI_PADDING siempre estará en ON y cualquier aplicación que establezca explícitamente la opción en OFF producirá un error. Evite utilizar esta característica en nuevos trabajos de desarrollo y tenga previsto modificar las aplicaciones que actualmente la utilizan. Se recomienda establecer siempre ANSI_PADDING en ON. ANSI_PADDING también debe estar en ON al crear o tratar índices en columnas calculadas o vistas indizadas.

char(n) y binary(n) las columnas que admiten valores NULL se rellenan hasta la longitud de la columna cuando ANSI_PADDING se establece en ON. Los ceros y los espacios en blanco finales se recortan si ANSI_PADDING es OFF. Las columnas char(n) y binary(n) que no permiten valores NULL siempre se rellenan hasta completar la longitud de la columna.

La configuración del nivel de conexión establecida mediante la instrucción SET invalida la configuración predeterminada del nivel de base de datos para ANSI_PADDING. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión mediante el establecimiento de ANSI_PADDING en ON para la sesión. Los clientes ejecutan la instrucción cuando se conecta a una instancia de SQL Server. Para más información, consulte SET ANSI_PADDING.

Para determinar el estado de esta opción, examine la columna is_ansi_padding_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAnsiPaddingEnabled de la función DATABASEPROPERTYEX.

ANSI_WARNINGS { ON | OFF }

  • ACTIVAR

    Se emiten errores o advertencias si se dan condiciones tales como la división por cero. También se emiten errores y advertencias cuando aparecen valores null en funciones de agregado.

  • Apagado

    No se genera ninguna advertencia ni se devuelven valores NULL si se producen condiciones como la división por cero.

Nota:

El valor de SET ANSI_WARNINGS debe ser ON al crear o realizar cambios en los índices en columnas calculadas o vistas indizadas.

La configuración del nivel de conexión establecida mediante la instrucción SET invalida la configuración predeterminada de la base de datos para ANSI_WARNINGS. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión mediante el establecimiento de ANSI_WARNINGS en ON para la sesión. Los clientes ejecutan la instrucción cuando se conecta a una instancia de SQL Server. Para más información, consulte SET ANSI_WARNINGS.

Para determinar el estado de esta opción, examine la columna is_ansi_warnings_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAnsiWarningsEnabled de la función DATABASEPROPERTYEX.

ARITHABORT { ON | OFF }

  • ACTIVAR

    Se finaliza una consulta cuando se produce un error de desbordamiento o de división por cero durante su ejecución.

  • Apagado

    Aparece un mensaje de advertencia cuando se produce uno de estos errores. La consulta, el proceso por lotes o la transacción continúa procesándose como si no se hubiera producido ningún error aunque se muestre una advertencia.

Nota:

El valor de SET ARITHABORT debe ser ON al crear o realizar cambios en los índices en columnas calculadas o vistas indizadas.

Para determinar el estado de esta opción, examine la columna is_arithabort_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsArithmeticAbortEnabled de la función DATABASEPROPERTYEX.

COMPATIBILITY_LEVEL = { 160 | 150 | 140 | 130 | 120 | 110 | 100 }

Para obtener más información, consulte nivel de compatibilidad de ALTER DATABASE.

CONCAT_NULL_YIELDS_NULL { ON | OFF }

  • ACTIVAR

    El resultado de una operación de concatenación es NULL si alguno de los operandos es NULL. Por ejemplo, la concatenación de la cadena de caracteres "Esto es" y NULL da como resultado el valor NULL, y no el valor "Esto es".

  • Apagado

    El valor NULL se trata como una cadena de caracteres vacía.

Nota:

El valor de CONCAT_NULL_YIELDS_NULL también debe ser ON al crear o realizar cambios en los índices en columnas calculadas o vistas indizadas.

En una versión futura de SQL Server, CONCAT_NULL_YIELDS_NULL siempre estará en ON y cualquier aplicación que establezca explícitamente la opción en OFF producirá un error. Evite utilizar esta característica en nuevos trabajos de desarrollo y tenga previsto modificar las aplicaciones que actualmente la utilizan.

La configuración del nivel de conexión establecida mediante la instrucción SET invalida la configuración predeterminada de la base de datos para CONCAT_NULL_YIELDS_NULL. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión y establecen CONCAT_NULL_YIELDS_NULL en ON para la sesión al realizar la conexión con una instancia de SQL Server. Para más información, consulte SET CONCAT_NULL_YIELDS_NULL.

Para determinar el estado de esta opción, examine la columna is_concat_null_yields_null_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsNullConcat de la función DATABASEPROPERTYEX.

NUMERIC_ROUNDABORT { ON | OFF }

  • ACTIVAR

    Se genera un error cuando se produce una pérdida de precisión en una expresión.

  • Apagado

    Las pérdidas de precisión no generan un mensaje de error y el resultado se redondea con la precisión de la columna o variable que lo almacena.

Importante

El valor de NUMERIC_ROUNDABORT debe ser OFF al crear o realizar cambios en índices de columnas calculadas o vistas indizadas.

Puede determinar el estado de esta opción en la columna is_numeric_roundabort_on de la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsNumericRoundAbortEnabled de la función DATABASEPROPERTYEX.

QUOTED_IDENTIFIER { ON | OFF }

  • ACTIVAR

    Las comillas dobles se pueden usar para identificadores delimitados.

    Todas las cadenas delimitadas por comillas dobles se interpretan como identificadores de objetos. Los identificadores entre comillas no tienen que adaptarse a las reglas de Transact-SQL para identificadores. Pueden ser palabras clave e incluir caracteres que no se permiten en los identificadores de Transact-SQL. Si una comilla doble (") forma parte del identificador, puede representarse entre dos comillas dobles ("").

  • Apagado

    Los identificadores no se pueden incluir entre comillas y deben seguir todas las reglas de Transact-SQL para los identificadores. Los literales se pueden delimitar con comillas simples o dobles.

SQL Server también permite delimitar los identificadores con corchetes ([ y ]). Los identificadores entre corchetes pueden usarse siempre, independientemente del valor de QUOTED_IDENTIFIER. Para obtener más información, consulte Identificadores de base de datos.

Al crear una tabla, la opción QUOTED IDENTIFIER siempre se almacena como ON en los metadatos de la tabla. La opción se almacena incluso si está establecida en OFF al crear la tabla.

La configuración en el nivel de conexión establecida mediante la instrucción SET invalida la configuración predeterminada de la base de datos para QUOTED_IDENTIFIER. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión estableciendo QUOTED_IDENTIFIER en ON. Los clientes ejecutan la instrucción cuando se conecta a una instancia de SQL Server. Para más información, consulte SET QUOTED_IDENTIFIER.

Para determinar el estado de esta opción, examine la columna is_quoted_identifier_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsQuotedIdentifiersEnabled de la función DATABASEPROPERTYEX.

RECURSIVE_TRIGGERS { ON | OFF }

  • ACTIVAR

    Se permite la activación recursiva de desencadenadores AFTER.

  • Apagado

    Para determinar el estado de esta opción, examine la columna is_recursive_triggers_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsRecursiveTriggersEnabled de la función DATABASEPROPERTYEX.

Nota:

La recursividad directa solo se evita cuando RECURSIVE_TRIGGERS se establece en OFF. Para deshabilitar la recursividad indirecta, también debe establecer la opción de servidor desencadenadores anidados en 0.

Para determinar el estado de esta opción, examine la columna is_recursive_triggers_onde la vista de catálogo sys.databases o la propiedad IsRecursiveTriggersEnabled de la función DATABASEPROPERTYEX.

<target_recovery_time_option> ::=

Especifica la frecuencia de puntos de comprobación indirectos por base de datos. A partir de SQL Server 2016 (13.x), el valor predeterminado para las nuevas bases de datos es 1 minuto, que indica que la base de datos usa puntos de control indirectos. Para las versiones anteriores, el valor predeterminado es 0, que indica que la base de datos usa puntos de control automáticos, cuya frecuencia depende de la configuración del intervalo de recuperación de la instancia del servidor. Microsoft recomienda un minuto para la mayoría de los sistemas.

TARGET_RECOVERY_TIME = target_recovery_time { SECONDS | MINUTES }

  • target_recovery_time

    Especifica el límite máximo de tiempo para recuperar la base de datos especificada en caso de bloqueo. target_recovery_time es del tipo int.

  • SECONDS

    Indica que target_recovery_time se expresa como el número de segundos.

  • MINUTES

    Indica que target_recovery_time se expresa como el número de minutos.

Para obtener más información sobre los puntos de control indirectos, consulte Puntos de control de base de datos.

WITH <termination> ::=

Especifica el momento en que se revierten las transacciones incompletas cuando la base de datos pasa de un estado a otro. Si se omite la cláusula de terminación, la instrucción ALTER DATABASE espera indefinidamente a que se produzca un bloqueo en la base de datos. Solamente se puede especificar una cláusula de terminación y debe seguir a las cláusulas SET.

Nota:

No todas las opciones de base de datos usan la cláusula WITH <termination>. Para más información, consulte la tabla en "Opciones de configuración de la sección "Comentarios" de este artículo.

  • ROLLBACK AFTER integer [SECONDS] | ROLLBACK IMMEDIATE

    Especifica si la operación de reversión se ejecuta transcurrido un número de segundos determinado o de forma inmediata.

  • NO_WAIT

    Especifica que se produce un error en la solicitud si el estado de la base de datos o el cambio de opción solicitados no se pueden completar inmediatamente. Completarse inmediatamente significa que no se espera a que las transacciones se confirmen o reviertan por su cuenta.

<temporal_history_retention> ::=

Opciones de Set

Para recuperar la configuración actual de las opciones de base de datos, use la vista de catálogo sys.databases o DATABASEPROPERTYEX.

Una vez configurada una opción de la base de datos, la nueva configuración surte efecto de inmediato.

Puede cambiar los valores predeterminados de cualquiera de las opciones de las bases de datos recién creadas. Para ello, cambie la opción adecuada de base de datos en la base de datos model.

No todas las opciones de base de datos usan la cláusula WITH <termination> ni se pueden especificar en combinación con otras opciones. En la siguiente tabla se incluyen estas opciones, su estado y el estado de terminación.

Categoría de opciones Se puede especificar con otras opciones Puede usar la cláusula WITH <termination>
<auto_option> No
<change_tracking_option>
<cursor_option> No
<db_encryption_option> No
<db_update_option>
<db_user_access_option>
<delayed_durability_option>
<parameterization_option>
ALLOW_SNAPSHOT_ISOLATION No No
READ_COMMITTED_SNAPSHOT No
MEMORY_OPTIMIZED_ELEVATE_TO_SNAPSHOT
DATE_CORRELATION_OPTIMIZATION
<sql_option> No
<target_recovery_time_option> No

Ejemplos

A. Establecimiento de la base de datos en READ_ONLY

Cambiar el estado de una base de datos o un grupo de archivos a READ_ONLY o READ_WRITE requiere acceso exclusivo a la base de datos y puede tardar unos segundos en completarse. En el siguiente ejemplo la base de datos se establece en el modo RESTRICTED_USER para limitar el acceso. A continuación, el ejemplo establece el estado de la base de datos AdventureWorks2022 en READ_ONLY y devuelve el acceso a la base de datos a todos los usuarios.

--Connect to [database_name];
GO
ALTER DATABASE [database_name]
SET RESTRICTED_USER;
GO
ALTER DATABASE [database_name]
SET READ_ONLY
--`SET READ_ONLY` command might take a few seconds to complete.
GO
ALTER DATABASE [database_name]
SET MULTI_USER;
GO

Para volver a establecer la base de datos en el modo de lectura y escritura:

--Connect to [database_name];
GO
ALTER DATABASE [database_name]
SET READ_WRITE
GO

Para comprobarlo:

SELECT [name], user_access_desc, is_read_only FROM sys.databases
WHERE [name] = 'database_name'
GO

B. Habilitación del aislamiento de instantáneas en una base de datos

En el siguiente ejemplo se habilita la opción del marco de aislamiento de instantánea para la base de datos AdventureWorks2022 .

--Connect to [database_name]
GO
ALTER DATABASE [database_name]
SET ALLOW_SNAPSHOT_ISOLATION ON;
GO

Compruebe el estado del snapshot_isolation_framework en la base de datos.

--Connect to [database_name]
SELECT name, snapshot_isolation_state,
    snapshot_isolation_state_desc AS description
FROM sys.databases
WHERE name = N'database_name';
GO

El conjunto de resultados muestra que el marco de aislamiento de instantánea está habilitado.

name snapshot_isolation_state description
[database_name] 1 ACTIVAR

C. Habilitación, modificación o deshabilitación del seguimiento de cambios

En el ejemplo siguiente se habilita el seguimiento de cambios para la base de datos AdventureWorks2022 y se establece el período de retención en 2 días.

--Connect to [database_name]
ALTER DATABASE [database_name]
SET CHANGE_TRACKING = ON
(AUTO_CLEANUP = ON, CHANGE_RETENTION = 2 DAYS);

En el ejemplo siguiente se muestra cómo cambiar el período de retención a 3 días.

--Connect to [database_name]
ALTER DATABASE [database_name]
SET CHANGE_TRACKING (CHANGE_RETENTION = 3 DAYS);

En el ejemplo siguiente se muestra cómo deshabilitar el seguimiento de cambios para la base de datos AdventureWorks2022 .

--Connect to [database_name]
ALTER DATABASE [database_name]
SET CHANGE_TRACKING = OFF;

D. Habilitación del Almacén de consultas

En el ejemplo siguiente se habilita el Almacén de consultas y configura los parámetros del Almacén de consultas.

--Connect to [database_name]
ALTER DATABASE [database_name]
SET QUERY_STORE = ON
    (
      OPERATION_MODE = READ_WRITE,
      CLEANUP_POLICY = ( STALE_QUERY_THRESHOLD_DAYS = 90 ),
      DATA_FLUSH_INTERVAL_SECONDS = 900,
      QUERY_CAPTURE_MODE = AUTO,
      MAX_STORAGE_SIZE_MB = 1024,
      INTERVAL_LENGTH_MINUTES = 60
    );

E. Habilitación del Almacén de consultas con estadísticas de espera

En el ejemplo siguiente se habilita el Almacén de consultas y configura sus parámetros.

--Connect to [database_name]
ALTER DATABASE [database_name]
SET QUERY_STORE = ON
    (
      OPERATION_MODE = READ_WRITE,
      CLEANUP_POLICY = ( STALE_QUERY_THRESHOLD_DAYS = 90 ),
      DATA_FLUSH_INTERVAL_SECONDS = 900,
      MAX_STORAGE_SIZE_MB = 1024,
      INTERVAL_LENGTH_MINUTES = 60,
      SIZE_BASED_CLEANUP_MODE = AUTO,
      MAX_PLANS_PER_QUERY = 200,
      WAIT_STATS_CAPTURE_MODE = ON
    );

F. Habilitación del Almacén de consultas con las opciones de directiva de captura personalizadas

En el ejemplo siguiente se habilita el Almacén de consultas y configura sus parámetros.

--Connect to [database_name]
ALTER DATABASE [database_name]
SET QUERY_STORE = ON
    (
      OPERATION_MODE = READ_WRITE,
      CLEANUP_POLICY = ( STALE_QUERY_THRESHOLD_DAYS = 90 ),
      DATA_FLUSH_INTERVAL_SECONDS = 900,
      MAX_STORAGE_SIZE_MB = 1024,
      INTERVAL_LENGTH_MINUTES = 60,
      SIZE_BASED_CLEANUP_MODE = AUTO,
      MAX_PLANS_PER_QUERY = 200,
      WAIT_STATS_CAPTURE_MODE = ON,
      QUERY_CAPTURE_MODE = CUSTOM,
      QUERY_CAPTURE_POLICY = (
        STALE_CAPTURE_POLICY_THRESHOLD = 24 HOURS,
        EXECUTION_COUNT = 30,
        TOTAL_COMPILE_CPU_TIME_MS = 1000,
        TOTAL_EXECUTION_CPU_TIME_MS = 100
      )
    );

* SQL Managed Instance *  

 

Instancia administrada de Azure SQL

Los niveles de compatibilidad son opciones de SET, pero se describen en nivel de compatibilidad de ALTER DATABASE.

Nota:

Es posible configurar muchas opciones SET de la base de datos para la sesión actual mediante Instrucciones SET, aunque generalmente las configuran las aplicaciones al realizar la conexión. Las opciones SET de nivel de sesión reemplazan a los valores ALTER DATABASE SET. Las opciones de base de datos descritas en las secciones siguientes son valores que se pueden establecer para sesiones que no proporcionan de forma explícita otros valores de opciones SET.

Sintaxis

ALTER DATABASE { database_name | Current }
SET
{
    <optionspec> [ ,...n ]
}
;

<optionspec> ::=
{
    <auto_option>
  | <change_tracking_option>
  | <cursor_option>
  | <db_encryption_option>
  | <delayed_durability_option>
  | <parameterization_option>
  | <query_store_options>
  | <snapshot_option>
  | <sql_option>
  | <target_recovery_time_option>
  | <termination>
  | <temporal_history_retention>
}
;
<auto_option> ::=
{
    AUTO_CREATE_STATISTICS { OFF | ON [ ( INCREMENTAL = { ON | OFF } ) ] }
  | AUTO_SHRINK { ON | OFF }
  | AUTO_UPDATE_STATISTICS { ON | OFF }
  | AUTO_UPDATE_STATISTICS_ASYNC { ON | OFF }
}

<automatic_tuning_option> ::=
{
    AUTOMATIC_TUNING ( FORCE_LAST_GOOD_PLAN = { DEFAULT | ON | OFF } )
}

<change_tracking_option> ::=
{
    CHANGE_TRACKING
    {
       = OFF
     | = ON [ ( <change_tracking_option_list > [,...n] ) ]
     | ( <change_tracking_option_list> [,...n] )
    }
}

<change_tracking_option_list> ::=
   {
       AUTO_CLEANUP = { ON | OFF }
     | CHANGE_RETENTION = retention_period { DAYS | HOURS | MINUTES }
   }

<cursor_option> ::=
{
    CURSOR_CLOSE_ON_COMMIT { ON | OFF }
}

<db_encryption_option> ::=
  ENCRYPTION { ON | OFF }

<delayed_durability_option> ::=DELAYED_DURABILITY = { DISABLED | ALLOWED | FORCED }

<parameterization_option> ::=
  PARAMETERIZATION { SIMPLE | FORCED }

<query_store_options> ::=
{
  QUERY_STORE
  {
    = OFF
    | = ON [ ( <query_store_option_list> [,... n] ) ]
    | ( < query_store_option_list> [,... n] )
    | CLEAR [ ALL ]
  }
}

<query_store_option_list> ::=
{
  OPERATION_MODE = { READ_WRITE | READ_ONLY }
  | CLEANUP_POLICY = ( STALE_QUERY_THRESHOLD_DAYS = number )
  | DATA_FLUSH_INTERVAL_SECONDS = number
  | MAX_STORAGE_SIZE_MB = number
  | INTERVAL_LENGTH_MINUTES = number
  | SIZE_BASED_CLEANUP_MODE = { AUTO | OFF }
  | QUERY_CAPTURE_MODE = { ALL | AUTO | CUSTOM | NONE }
  | MAX_PLANS_PER_QUERY = number
  | WAIT_STATS_CAPTURE_MODE = { ON | OFF }
  | QUERY_CAPTURE_POLICY = ( <query_capture_policy_option_list> [,...n] )
}

<query_capture_policy_option_list> :: =
{
    STALE_CAPTURE_POLICY_THRESHOLD = number { DAYS | HOURS }
    | EXECUTION_COUNT = number
    | TOTAL_COMPILE_CPU_TIME_MS = number
    | TOTAL_EXECUTION_CPU_TIME_MS = number
}

<snapshot_option> ::=
{
    ALLOW_SNAPSHOT_ISOLATION { ON | OFF }
  | READ_COMMITTED_SNAPSHOT { ON | OFF }
  | MEMORY_OPTIMIZED_ELEVATE_TO_SNAPSHOT { ON | OFF }
}
<sql_option> ::=
{
    ANSI_NULL_DEFAULT { ON | OFF }
  | ANSI_NULLS { ON | OFF }
  | ANSI_PADDING { ON | OFF }
  | ANSI_WARNINGS { ON | OFF }
  | ARITHABORT { ON | OFF }
  | COMPATIBILITY_LEVEL = { 160 | 150 | 140 | 130 | 120 | 110 | 100 }
  | CONCAT_NULL_YIELDS_NULL { ON | OFF }
  | NUMERIC_ROUNDABORT { ON | OFF }
  | QUOTED_IDENTIFIER { ON | OFF }
  | RECURSIVE_TRIGGERS { ON | OFF }
}

<temporal_history_retention>::= TEMPORAL_HISTORY_RETENTION { ON | OFF }

Argumentos

database_name

Nombre de la base de datos que se va a modificar.

CURRENT

CURRENT realiza la acción en la base de datos actual. CURRENT no se admite para todas las opciones en todos los contextos. Si CURRENT produce un error, proporcione el nombre de la base de datos.

<auto_option> ::=

Controla las opciones automáticas.

AUTO_CREATE_STATISTICS { ON | OFF }

  • ACTIVAR

    El optimizador de consultas crea estadísticas en columnas únicas de los predicados de consulta, según sea necesario, para mejorar los planes de consulta y el rendimiento de las consultas. Estas estadísticas de columna única se crean cuando el optimizador de consultas las compila. Las estadísticas de columna única solamente se crean en las columnas que ya no son la primera columna de un objeto de estadísticas existente.

    El valor predeterminado es ON. Recomendamos utilizar la configuración predeterminada para la mayoría de las bases de datos.

  • Apagado

    El optimizador de consultas no crea las estadísticas en columnas únicas de los predicados de consulta cuando compila las consultas. Establecer esta opción en OFF puede producir planes de consulta poco óptimos y un rendimiento degradado de las consultas.

    Para determinar el estado de esta opción, examine la columna is_auto_create_stats_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAutoCreateStatistics de la función DATABASEPROPERTYEX.

    Para más información, vea la sección "Opciones de estadísticas" en Estadísticas.

INCREMENTAL = ON | OFF

Establezca AUTO_CREATE_STATISTICS en ON y establezca INCREMENTAL en ON. Esta configuración crea automáticamente estadísticas como incrementales siempre que se admitan estadísticas incrementales. El valor predeterminado es OFF. Para más información, consulte CREATE STATISTICS.

AUTO_SHRINK { ON | OFF }

  • ACTIVAR

    Los archivos de la base de datos se pueden reducir periódicamente. A menos que tenga un requisito específico, no establezca la opción AUTO_SHRINK base de datos en ACTIVADO. Para más información, consulte Shrink a Database.

    Pueden reducirse automáticamente los archivos de datos y los archivos de registro. AUTO_SHRINK reduce el tamaño del registro de transacciones solo si establece la base de datos en el modelo de recuperación SIMPLE o si realiza una copia de seguridad del registro. Cuando se establece en OFF, los archivos de la base de datos no se reducen de forma automática durante las comprobaciones periódicas del espacio no utilizado.

    La opción AUTO_SHRINK reduce los archivos cuando no se utiliza más de un 25% del espacio del archivo. La opción hace que el archivo se reduzca a uno de dos tamaños. Se reduce al que sea más grande de los siguientes:

    • El tamaño donde el 25 por ciento del archivo es espacio no utilizado
    • El tamaño del archivo cuando se creó

    No puede reducir una base de datos de solo lectura.

  • Apagado

    Los archivos de base de datos no se reducen automáticamente durante las comprobaciones periódicas de espacio sin usar.

Para determinar el estado de esta opción, examine la columna is_auto_shrink_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAutoShrink de la función DATABASEPROPERTYEX.

Nota:

La opción AUTO_SHRINK no está disponible en una base de datos independiente.

AUTO_UPDATE_STATISTICS { ON | OFF }

  • ACTIVAR

    Especifica que el optimizador de consultas actualiza las estadísticas cuando las usa una consulta y puedan estar obsoletas. Las estadísticas se vuelven obsoletas después de que operaciones de inserción, actualización, eliminación o combinación cambien la distribución de los datos en la tabla o la vista indizada. Para determinar cuándo las estadísticas pueden quedar obsoletas, el optimizador de consultas cuenta el número de modificaciones de datos desde la actualización más reciente de las estadísticas y compara el número de modificaciones con un umbral. El umbral se basa en el número de filas de la tabla o la vista indizada.

    El optimizador de consultas comprueba si hay estadísticas obsoletas antes de compilar una consulta y ejecuta un plan de consulta almacenado en caché. El optimizador de consultas usa las columnas, tablas y vistas indexadas del predicado de consulta para determinar qué estadísticas podrían estar obsoletas. El optimizador de consultas determina esta información antes de compilar una consulta. Antes de ejecutar un plan de consulta almacenado en caché, Motor de base de datos comprueba que el plan de consulta haga referencia a las estadísticas actualizadas.

    La opción AUTO_UPDATE_STATISTICS se aplica a las estadísticas creadas para índices y columnas únicas de los predicados de consulta, así como a las estadísticas creadas con la instrucción CREATE STATISTICS. Esta opción también se aplica a las estadísticas filtradas.

    El valor predeterminado es ON. Recomendamos utilizar la configuración predeterminada para la mayoría de las bases de datos.

    Utilice la opción AUTO_UPDATE_STATISTICS_ASYNC para especificar si las estadísticas se actualizan sincrónica o asincrónicamente.

  • Apagado

    Especifica que el optimizador de consultas no actualiza las estadísticas cuando una consulta las usa. El optimizador de consultas tampoco actualiza las estadísticas cuando podrían estar obsoletas. Establecer esta opción en OFF puede producir planes de consulta poco óptimos y un rendimiento degradado de las consultas.

Para determinar el estado de esta opción, examine la columna is_auto_update_stats_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAutoUpdateStatistics de la función DATABASEPROPERTYEX.

Para más información, vea la sección "Uso de las opciones de estadísticas de toda la base de datos" de Estadísticas.

AUTO_UPDATE_STATISTICS_ASYNC { ON | OFF }

  • ACTIVAR

    Especifica que las actualizaciones de las estadísticas para la opción AUTO_UPDATE_STATISTICS son asincrónicas. El optimizador de consultas no espera a que finalicen las actualizaciones de las estadísticas para compilar las consultas.

    La configuración de esta opción en ON no surte efecto a menos que AUTO_UPDATE_STATISTICS se establezca en ON.

    De forma predeterminada, la opción AUTO_UPDATE_STATISTICS_ASYNC se establece en OFF y el optimizador de consultas actualiza las estadísticas de manera sincrónica.

  • Apagado

    Especifica que las actualizaciones de las estadísticas para la opción AUTO_UPDATE_STATISTICS son sincrónicas. El optimizador de consultas espera a que finalicen las actualizaciones de las estadísticas para compilar las consultas.

    La configuración de esta opción en OFF no surte efecto a menos que AUTO_UPDATE_STATISTICS esté configurado en ON.

Para determinar el estado de esta opción, examine la columna is_auto_update_stats_async_on en la vista de catálogo sys.databases.

Para obtener más información sobre cuándo usar las actualizaciones de estadísticas sincrónicas o asincrónicas, vea la sección "Uso de las opciones de estadísticas de toda la base de datos" de Estadísticas.

<automatic_tuning_option> ::=

Controla las opciones automáticas para el ajuste automático.

FORCE_LAST_GOOD_PLAN = { DEFAULT | ON | OFF }

Habilita o deshabilita la opción FORCE_LAST_GOOD_PLAN de .

  • DEFAULT

    El valor predeterminado de Azure SQL Managed Instance es ON.

  • ACTIVAR

    Motor de base de datos fuerza automáticamente el último buen plan conocido en las consultas de Transact-SQL, donde el nuevo plan de consulta provoca regresiones de rendimiento. El parámetro Motor de base de datos supervisa continuamente el rendimiento de la consulta Transact-SQL con el plan forzado. Si hay mejoras de rendimiento, el motor de base de datos sigue usando el último plan correcto conocido. Si no se detectan mejoras de rendimiento, el motor de base de datos genera un nuevo plan de consulta. Se produce un error en la instrucción si el Almacén de consultas no está habilitado o no está en modo de lectura y escritura. Este es el valor predeterminado.

  • Apagado

    Motor de base de datos informa de posibles regresiones de rendimiento de consultas provocadas por cambios del plan de consulta en la vista sys.dm_db_tuning_recommendations, Sin embargo, estas recomendaciones no se aplican automáticamente. Para supervisar las recomendaciones activas y corregir los problemas identificados, los usuarios pueden aplicar los scripts de Transact-SQL que se muestran en la vista.

<change_tracking_option> ::=

Controla las opciones de seguimiento de cambios. Puede habilitar el seguimiento de cambios, establecer y cambiar opciones, y deshabilitar el seguimiento de cambios. Para obtener ejemplos, vea la sección Ejemplos más adelante en este artículo.

  • ACTIVAR

    Habilita el seguimiento de cambios para la base de datos. Si habilita el seguimiento de cambios, también puede establecer las opciones AUTO CLEANUP y CHANGE RETENTION.

AUTO_CLEANUP = { ON | OFF }

  • ACTIVAR

    La información sobre el seguimiento de cambios se quita de forma automática después del período de retención especificado.

  • Apagado

    Los datos del seguimiento de cambios no se quitan de la base de datos.

CHANGE_RETENTION = período_de_retención { DAYS | HOURS | MINUTES }

Especifica el período mínimo para mantener la información del seguimiento de cambios en la base de datos. Los datos solamente se quitan cuando el valor AUTO_CLEANUP es ON.

retention_period es un entero que especifica el componente numérico del período de retención.

El período de retención predeterminado es de 2 días. El período de retención mínimo es de 1 minuto. El tipo de retención predeterminado es DAYS.

  • Apagado

    Deshabilita el seguimiento de cambios para la base de datos. Deshabilite el seguimiento de cambios en todas las tablas para poder deshabilitarlo en la base de datos.

<cursor_option> ::=

Controla las opciones del cursor.

CURSOR_CLOSE_ON_COMMIT { ON | OFF }

  • ACTIVAR

    Todos los cursores abiertos cuando confirma o deshace una transacción se cierran.

  • Apagado

    Los cursores permanecen abiertos cuando se confirma una transacción. Cuando se revierte se cierran todos los cursores, excepto los que están definidos como INSENSITIVE o STATIC.

La configuración del nivel de conexión, establecida mediante la instrucción SET, invalida la configuración predeterminada de la base de datos para CURSOR_CLOSE_ON_COMMIT. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión que establece CURSOR_CLOSE_ON_COMMIT en OFF para la sesión. Los clientes ejecutan la instrucción cuando se conecta a una instancia de SQL Server. Para más información, consulte SET CURSOR_CLOSE_ON_COMMIT.

Para determinar el estado de esta opción, examine la columna is_cursor_close_on_commit_on de la vista de catálogo sys.databases o la propiedad IsCloseCursorsOnCommitEnabled de la función DATABASEPROPERTYEX. El cursor se desasigna implícitamente solamente cuando se realiza la desconexión. Para más información, consulte DECLARE CURSOR.

<db_encryption_option> ::=

Controla el estado del cifrado de la base de datos.

ENCRYPTION { ON | OFF }

Establece que se cifre (ON) o no se cifre (OFF) la base de datos. Para más información sobre el cifrado de bases de datos, consulte cifrado de datos transparente (TDE)y Cifrado de datos transparente para Azure SQL Database, Azure SQL Managed Instance y Azure Synapse Analytics.

Cuando el cifrado está habilitado en el nivel de base de datos, todos los grupos de archivos se cifran. Los nuevos grupos de archivos heredan la propiedad cifrada. Si algún grupo de archivos de la base de datos se establece en READ ONLY, se produce un error en la operación de cifrado de la base de datos.

Puede ver el estado del cifrado de la base de datos mediante la vista de administración dinámica sys.dm_database_encryption_keys.

<delayed_durability_option> ::=

Controla si las transacciones se confirman con perdurabilidad total o diferida.

  • DISABLED

    Todas las transacciones tras SET DISABLED son totalmente perdurables. Se omiten las opciones de perdurabilidad que se establecen en un bloque ATOMIC o en una instrucción de confirmación.

  • ALLOWED

    Todas las transacciones tras SET ALLOWED son totalmente perdurables o de perdurabilidad diferida, dependiendo de la opción de perdurabilidad establecida en el bloque ATOMIC o la instrucción de confirmación.

  • FORCED

    Todas las transacciones tras SET FORCED son de perdurabilidad diferida. Se omiten las opciones de perdurabilidad que se establecen en un bloque ATOMIC o en una instrucción de confirmación.

<PARAMETERIZATION_option> ::=

Controla la opción de parametrización.

PARAMETERIZATION { SIMPLE | FORCED }

  • SIMPLE

    Las consultas incluyen parámetros en función del comportamiento predeterminado de la base de datos.

  • FORCED

SQL Server incluye parámetros para todas las consultas de la base de datos.

El valor actual de esta opción se puede determinar mediante el examen de la columna is_parameterization_forced en la vista de catálogo sys.databases.

<query_store_options> ::=

  • ON | OFF | CLEAR [ ALL ]

    Controla si el almacén de consultas está habilitado en esta base de datos y también controla la eliminación del contenido del almacén de consultas.

    • ACTIVAR

      Habilita el Almacén de consultas.

    • Apagado

      Deshabilita el Almacén de consultas. Este es el valor predeterminado.

    • CLEAR

      Quita el contenido del Almacén de consultas.

OPERATION_MODE

Describe el modo de operación del Almacén de consultas. Los valores válidos son READ_ONLY y READ_WRITE. En el modo READ_WRITE, el Almacén de consultas recopila y continúa el plan de consultas y la información de estadística del tiempo de ejecución. En el modo READ_ONLY, la información se puede leer del almacén de consultas, pero no se agrega información nueva. Si se ha agotado el espacio máximo asignado del Almacén de consultas, el Almacén de consultas cambia el modo de operación a READ_ONLY.

CLEANUP_POLICY

Describe la directiva de retención de datos del Almacén de consultas. STALE_QUERY_THRESHOLD_DAYS determina el número de días durante los que se conserva la información de una consulta en el Almacén de consultas. STALE_QUERY_THRESHOLD_DAYS es de tipo bigint. El valor predeterminado es 30. En la edición SQL Database Basic, el valor predeterminado es 7 días.

DATA_FLUSH_INTERVAL_SECONDS

Determina la frecuencia con la que los datos escritos en el Almacén de consultas se conservan en el disco. Para optimizar el rendimiento, los datos recopilados por el Almacén de consultas se escriben de manera asincrónica en el disco. La frecuencia con la que se produce esta transferencia asincrónica se configura mediante el argumento DATA_FLUSH_INTERVAL_SECONDS. DATA_FLUSH_INTERVAL_SECONDS es de tipo bigint. El valor predeterminado es 900 (15 minutos).

MAX_STORAGE_SIZE_MB

Determina el espacio asignado al Almacén de consultas. MAX_STORAGE_SIZE_MB es de tipo bigint. El valor predeterminado es 100 MB.

El límite MAX_STORAGE_SIZE_MB no se aplica de forma estricta. El tamaño de almacenamiento solo se comprueba cuando el almacén de consultas escribe datos en el disco. Este intervalo se establece mediante la opción DATA_FLUSH_INTERVAL_SECONDS o la opción de diálogo Intervalo de vaciado de datos del Almacén de consultas de Management Studio. El valor predeterminado de intervalo es 900 segundos (o 15 minutos).

Si el Almacén de consultas ha infringido el límite de MAX_STORAGE_SIZE_MB entre las comprobaciones de tamaño de almacenamiento, realiza la transición al modo de solo lectura. Si SIZE_BASED_CLEANUP_MODE está habilitado, también se desencadena el mecanismo de limpieza para aplicar el límite de MAX_STORAGE_SIZE_MB.

Una vez que se ha borrado suficiente espacio, el modo almacén de consultas cambia automáticamente a lectura y escritura.

Importante

  • Si cree que la captura de carga de trabajo necesita más de 10 GB de espacio en disco, probablemente debería replantear y optimizar la carga de trabajo para reutilizar los planes de consulta (por ejemplo, mediante parametrización forzadao ajustar las configuraciones del Almacén de consultas.
  • A partir de SQL Server 2019 (15.x) y en Azure SQL Database, puede establecer QUERY_CAPTURE_MODE en PERSONALIZADO para obtener un control adicional sobre la directiva de captura de consultas.
  • El límite del valor de MAX_STORAGE_SIZE_MB es de 10 240 MB en Azure SQL Managed Instance.

INTERVAL_LENGTH_MINUTES

Determina el intervalo de tiempo en el que se agregan los datos de estadísticas de ejecución en tiempo de ejecución al Almacén de consultas. Para optimizar el uso del espacio, se agregan las estadísticas de ejecución en tiempo de ejecución en el almacén de estadísticas de tiempo de ejecución en una ventana de tiempo fijo. Esta ventana de tiempo fijo se configura con el argumento INTERVAL_LENGTH_MINUTES. INTERVAL_LENGTH_MINUTES es de tipo bigint. El valor predeterminado es 60.

SIZE_BASED_CLEANUP_MODE = { AUTO | OFF }

Controla si la limpieza se activa automáticamente cuando la cantidad total de datos se acerca al tamaño máximo.

  • Apagado

    La limpieza basada en tamaño no se activa automáticamente.

  • AUTO

    La limpieza basada en tamaño se activa automáticamente cuando el tamaño del disco alcanza los 90% de max_storage_size_mb. La limpieza según el tamaño quita primero las consultas menos caras y más antiguas. Se detiene aproximadamente en el 80 % de max_storage_size_mb. Es el valor de configuración predeterminado.

SIZE_BASED_CLEANUP_MODE es de tipo nvarchar.

QUERY_CAPTURE_MODE { ALL | AUTO | CUSTOM | NONE }

Designa el modo de captura de consulta que está activo.

  • ALL

    Se capturan todas las consultas.

  • AUTO

    Captura consultas pertinentes en función del consumo de recursos y el recuento de ejecuciones. Es el valor de configuración predeterminado para Azure SQL Database.

  • Ninguno

    Detiene la captura de nuevas consultas. El Almacén de consultas sigue recopilando estadísticas de compilación y tiempo de ejecución para las consultas que ya se capturaron. Use esta configuración con precaución, ya que es posible que no capture consultas importantes.

QUERY_CAPTURE_MODE es de tipo nvarchar.

max_plans_per_query

Entero que representa el número máximo de planes que se tienen para cada consulta. MAX_PLANS_PER_QUERY es del tipo int. El valor predeterminado es 200.

WAIT_STATS_CAPTURE_MODE { ON | OFF }

Controla si las estadísticas de espera se capturan por consulta.

  • ACTIVAR

    Se captura información de estadísticas de espera por consulta. Este es el valor de configuración predeterminado.

  • Apagado

    No se captura la información de estadísticas de espera por consulta.

<query_capture_policy_option_list> :: =

Controla las opciones de directiva de captura de Almacén de consultas. Excepto en STALE_CAPTURE_POLICY_THRESHOLD, estas opciones definen las condiciones OR que se tienen que dar para que las consultas se capturen en el valor definido en el umbral de la directiva de capturas obsoletas.

STALE_CAPTURE_POLICY_THRESHOLD = entero { DAYS | HOURS }

Define el período de intervalo de evaluación para determinar si se debe capturar una consulta. El valor predeterminado es de 1 día y puede establecerse de 1 hora a 7 días.

EXECUTION_COUNT = entero

Define el número de veces que se ejecuta una consulta durante el período de evaluación. El valor predeterminado es 30, lo que significa que, para el valor predeterminado del umbral de la directiva de capturas obsoletas, una consulta se tendrá que ejecutar al menos 30 veces en un día para que se conserve en el almacén de consultas. EXECUTION_COUNT es del tipo int.

TOTAL_COMPILE_CPU_TIME_MS = entero

Define el tiempo total de CPU de compilación transcurrido que usa una consulta durante el período de evaluación. El valor predeterminado es 1000, lo que significa que, para el valor predeterminado del umbral de la directiva de capturas obsoletas, una consulta tendrá que invertir un total de al menos un segundo de tiempo de CPU durante la compilación de consulta en un día para conservarse en el Almacén de consultas. TOTAL_COMPILE_CPU_TIME_MS es del tipo int.

TOTAL_EXECUTION_CPU_TIME_MS = entero

Define el tiempo de ejecución total de CPU transcurrido que ha utilizado una consulta durante el período de evaluación. El valor predeterminado es 100, lo que significa que, para el valor predeterminado del umbral de la directiva de capturas obsoletas, una consulta tendrá que invertir un total de al menos 100 ms de tiempo de CPU durante la ejecución en un día para que se conserve en el almacén de consultas. TOTAL_EXECUTION_CPU_TIME_MS es del tipo int.

<snapshot_option> ::=

Determina el nivel de aislamiento de transacción.

ALLOW_SNAPSHOT_ISOLATION { ON | OFF }

  • ACTIVAR

    Habilita la opción de instantánea en el nivel de base de datos. Cuando se habilita, las instrucciones DML inician la generación de versiones de fila aunque ninguna transacción utilice el aislamiento de instantánea. Una vez habilitada esta opción, las transacciones pueden especificar el nivel de aislamiento de transacción SNAPSHOT. Si se ejecuta una transacción en el nivel de aislamiento SNAPSHOT, todas las instrucciones verán una instantánea de los datos tal como estaban al inicio de la transacción. Si una transacción ejecutada en el nivel de aislamiento SNAPSHOT tiene acceso a los datos de varias bases de datos, ALLOW_SNAPSHOT_ISOLATION debe establecerse en ON en todas las bases de datos o cada instrucción de la transacción debe utilizar sugerencias de bloqueo en cualquier referencia de una cláusula FROM a una tabla de una base de datos donde ALLOW_SNAPSHOT_ISOLATION sea OFF.

  • Apagado

    Desactiva la opción de instantánea en el nivel de base de datos. Las transacciones no pueden especificar el nivel de aislamiento de la transacción SNAPSHOT.

Si se establece ALLOW_SNAPSHOT_ISOLATION en un estado nuevo (de ON a OFF o de OFF a ON), ALTER DATABASE no devuelve el control al autor de la llamada hasta confirmar todas las transacciones existentes de la base de datos. Si la base de datos ya se encuentra en el estado especificado en la instrucción ALTER DATABASE, se devuelve de inmediato el control al autor de la llamada. Use sys.dm_tran_active_snapshot_database_transactions para determinar si hay transacciones de ejecución prolongada si la instrucción ALTER DATABASE no devuelve resultados rápidamente. Si se cancela la instrucción ALTER DATABASE, la base de datos permanece en el estado en que estaba al iniciar ALTER DATABASE. La vista de catálogo sys.databases indica el estado de las transacciones de aislamiento de instantáneas en la base de datos. Si snapshot_isolation_state_desc = IN_TRANSITION_TO_ON, la instrucción ALTER DATABASE ... ALLOW_SNAPSHOT_ISOLATION OFF pausa seis segundos y vuelve a intentar la operación.

No puede cambiar el estado de ALLOW_SNAPSHOT_ISOLATION si la base de datos está establecida en OFFLINE.

Puede cambiar la configuración de ALLOW_SNAPSHOT_ISOLATION para las bases de datos master, model, msdb y tempdb. La configuración se mantiene cada vez que la instancia de Motor de base de datos se detiene y se reinicia si cambia la configuración para tempdb. Si cambia la configuración para la base de datos del sistema model, dicha configuración se convierte en la configuración predeterminada para todas las bases de datos nuevas que se crean, excepto para tempdb.

La opción es ON de forma predeterminada para las bases de datos master y msdb.

El valor actual de esta opción se puede determinar mediante el examen de la columna snapshot_isolation_state en la vista de catálogo sys.databases.

READ_COMMITTED_SNAPSHOT { ON | OFF }

  • ACTIVAR

    Habilita la opción Instantánea de lectura confirmada en el nivel de base de datos. Cuando se habilita, las instrucciones DML inician la generación de versiones de fila aunque ninguna transacción utilice el aislamiento de instantánea. Una vez habilitada esta opción, las transacciones que especifican el nivel de aislamiento READ COMMITTED usan versiones de fila en lugar de bloqueos. Todas las instrucciones ven una instantánea de los datos tal y como existen al inicio de la instrucción si una transacción se ejecuta en el nivel de aislamiento READ COMMITTED.

  • Apagado

    Desactiva la opción de instantánea de lectura confirmada en el nivel de base de datos. Las transacciones que especifican el nivel de aislamiento READ COMMITTED utilizan el bloqueo.

Para establecer READ_COMMITTED_SNAPSHOT en ON u OFF, no puede haber ninguna conexión activa a la base de datos, excepto la que ejecuta el comando ALTER DATABASE. Sin embargo, no es necesario que la base de datos esté en modo de usuario único. No puede cambiar el estado de esta opción si la base de datos está establecida en OFFLINE.

READ_COMMITTED_SNAPSHOT no se puede establecer en ON para las bases de datos del sistema master, tempdb o msdb. Si cambia la configuración para la base de datos del sistema model, dicha configuración se convierte en predeterminada para todas las bases de datos creadas, excepto para tempdb.

El valor actual de esta opción se puede determinar mediante el examen de la columna is_read_committed_snapshot_on en la vista de catálogo sys.databases.

Advertencia

Cuando se crea una tabla con DURABILITY = SCHEMA_ONLY, y posteriormente se cambia READ_COMMITTED_SNAPSHOT mediante ALTER DATABASE, se pierden los datos de la tabla.

MEMORY_OPTIMIZED_ELEVATE_TO_SNAPSHOT { ON | OFF }

  • ACTIVAR

    Cuando el nivel de aislamiento de transacción se establece en uno inferior a SNAPSHOT, todas las operaciones interpretadas de Transact-SQL en las tablas optimizadas para memoria se ejecutan con aislamiento SNAPSHOT. Los ejemplos de los niveles de aislamiento inferiores a la instantánea son READ COMMITTED o READ UNCOMMITTED. Estas operaciones se ejecutan si el nivel de aislamiento de transacción se establece explícitamente en el nivel de sesión o el valor predeterminado se utiliza de forma implícita.

  • Apagado

    No eleva el nivel de aislamiento de transacción para las operaciones interpretadas de Transact-SQL en las tablas optimizadas para memoria.

No puede cambiar el estado de MEMORY_OPTIMIZED_ELEVATE_TO_SNAPSHOT si la base de datos está establecida en OFFLINE.

El valor predeterminado es OFF.

El valor actual de esta opción se puede determinar mediante el examen de la columna is_memory_optimized_elevate_to_snapshot_on en la vista de catálogo sys.databases.

<sql_option> ::=

Controla las opciones de cumplimiento con ANSI en el nivel de base de datos.

ANSI_NULL_DEFAULT { ON | OFF }

Determina el valor predeterminado, NULL o NOT NULL, de una columna o del tipo definido por el usuario CLR para los que no se ha definido la nulabilidad explícitamente en las instrucciones CREATE TABLE o ALTER TABLE. Las columnas definidas con restricciones siguen las reglas de restricción que pueda ser esta configuración.

  • ACTIVAR

    El valor predeterminado es NULL.

  • Apagado

    El valor predeterminado es NOT NULL.

La configuración del nivel de conexión, establecida mediante la instrucción SET, invalida la configuración predeterminada del nivel de base de datos para ANSI_NULL_DEFAULT. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión mediante el establecimiento de ANSI_NULL_DEFAULT en ON para la sesión. Los clientes ejecutan la instrucción cuando se conecta a una instancia de SQL Server. Para más información, consulte SET ANSI_NULL_DFLT_ON.

Para la compatibilidad con ANSI, si se establece la opción de base de datos ANSI_NULL_DEFAULT en ON, el valor predeterminado cambia a NULL.

Para determinar el estado de esta opción, examine la columna is_ansi_null_default_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAnsiNullDefault de la función DATABASEPROPERTYEX.

ANSI_NULLS { ON | OFF }

  • ACTIVAR

    Todas las comparaciones con un valor NULL se evalúan como UNKNOWN.

  • Apagado

    Las comparaciones de valores no Unicode con un valor NULL se evalúan como TRUE si ambos valores son NULL.

Importante

En una versión futura de SQL Server, ANSI_NULLS siempre estará ON y cualquier aplicación que establezca explícitamente la opción en OFF producirá un error. Evite utilizar esta característica en nuevos trabajos de desarrollo y tenga previsto modificar las aplicaciones que actualmente la utilizan.

La configuración del nivel de conexión establecida mediante la instrucción SET invalida la configuración predeterminada de la base de datos para ANSI_NULLS. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión mediante el establecimiento de ANSI_NULLS en ON para la sesión. Los clientes ejecutan la instrucción cuando se conecta a una instancia de SQL Server. Para más información, consulte SET ANSI_NULLS.

Importante

El valor de SET ANSI_NULLS también debe estar en ON al crear o realizar cambios en los índices en columnas calculadas o vistas indizadas.

Para determinar el estado de esta opción, examine la columna is_ansi_nulls_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAnsiNullsEnabled de la función DATABASEPROPERTYEX.

ANSI_PADDING { ON | OFF }

  • ACTIVAR

    Las cadenas se rellenan a la misma longitud antes de la conversión. También se rellenan hasta la misma longitud antes de la inserción en un tipo de datos varchar o nvarchar.

  • Apagado

    Inserta espacios en blanco finales en los valores de caracteres en las columnas varchar o nvarchar. También deja los ceros a la derecha en los valores binarios insertados en columnas varbinary. Los valores no se rellenan hasta completar la longitud de la columna.

    Si se especifica OFF, esta opción solamente afecta a la definición de las columnas nuevas.

Importante

En una versión futura de SQL Server, ANSI_PADDING siempre estará en ON y cualquier aplicación que establezca explícitamente la opción en OFF producirá un error. Evite utilizar esta característica en nuevos trabajos de desarrollo y tenga previsto modificar las aplicaciones que actualmente la utilizan. Se recomienda establecer siempre ANSI_PADDING en ON. ANSI_PADDING también debe estar en ON al crear o tratar índices en columnas calculadas o vistas indizadas.

char(n) y binary(n) las columnas que admiten valores NULL se rellenan hasta la longitud de la columna cuando ANSI_PADDING se establece en ON. Los ceros y los espacios en blanco finales se recortan si ANSI_PADDING es OFF. Las columnas char(n) y binary(n) que no permiten valores NULL siempre se rellenan hasta completar la longitud de la columna.

La configuración del nivel de conexión establecida mediante la instrucción SET invalida la configuración predeterminada del nivel de base de datos para ANSI_PADDING. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión mediante el establecimiento de ANSI_PADDING en ON para la sesión. Los clientes ejecutan la instrucción cuando se conecta a una instancia de SQL Server. Para más información, consulte SET ANSI_PADDING.

Para determinar el estado de esta opción, examine la columna is_ansi_padding_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAnsiPaddingEnabled de la función DATABASEPROPERTYEX.

ANSI_WARNINGS { ON | OFF }

  • ACTIVAR

    Se emiten errores o advertencias si se dan condiciones tales como la división por cero. También se emiten errores y advertencias cuando aparecen valores null en funciones de agregado.

  • Apagado

    No se genera ninguna advertencia ni se devuelven valores NULL si se producen condiciones como la división por cero.

Importante

El valor de SET ANSI_WARNINGS debe ser ON al crear o realizar cambios en los índices en columnas calculadas o vistas indizadas.

La configuración del nivel de conexión establecida mediante la instrucción SET invalida la configuración predeterminada de la base de datos para ANSI_WARNINGS. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión mediante el establecimiento de ANSI_WARNINGS en ON para la sesión. Los clientes ejecutan la instrucción cuando se conecta a una instancia de SQL Server. Para más información, consulte SET ANSI_WARNINGS.

Para determinar el estado de esta opción, examine la columna is_ansi_warnings_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAnsiWarningsEnabled de la función DATABASEPROPERTYEX.

ARITHABORT { ON | OFF }

  • ACTIVAR

    Se finaliza una consulta cuando se produce un error de desbordamiento o de división por cero durante su ejecución.

  • Apagado

    Aparece un mensaje de advertencia cuando se produce uno de estos errores. La consulta, el proceso por lotes o la transacción continúa procesándose como si no se hubiera producido ningún error aunque se muestre una advertencia.

Importante

El valor de SET ARITHABORT debe ser ON al crear o realizar cambios en los índices en columnas calculadas o vistas indizadas.

Para determinar el estado de esta opción, examine la columna is_arithabort_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsArithmeticAbortEnabled de la función DATABASEPROPERTYEX.

COMPATIBILITY_LEVEL = { 160 | 150 | 140 | 130 | 120 | 110 | 100 }

Para obtener más información, consulte nivel de compatibilidad de ALTER DATABASE.

CONCAT_NULL_YIELDS_NULL { ON | OFF }

  • ACTIVAR

    El resultado de una operación de concatenación es NULL si alguno de los operandos es NULL. Por ejemplo, la concatenación de la cadena de caracteres "Esto es" y NULL da como resultado el valor NULL, y no el valor "Esto es".

  • Apagado

    El valor NULL se trata como una cadena de caracteres vacía.

Importante

El valor de CONCAT_NULL_YIELDS_NULL también debe ser ON al crear o realizar cambios en los índices en columnas calculadas o vistas indizadas.

En una versión futura de SQL Server, CONCAT_NULL_YIELDS_NULL siempre estará en ON y cualquier aplicación que establezca explícitamente la opción en OFF producirá un error. Evite utilizar esta característica en nuevos trabajos de desarrollo y tenga previsto modificar las aplicaciones que actualmente la utilizan.

La configuración del nivel de conexión establecida mediante la instrucción SET invalida la configuración predeterminada de la base de datos para CONCAT_NULL_YIELDS_NULL. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión y establecen CONCAT_NULL_YIELDS_NULL en ON para la sesión al realizar la conexión con una instancia de SQL Server. Para más información, consulte SET CONCAT_NULL_YIELDS_NULL.

Para determinar el estado de esta opción, examine la columna is_concat_null_yields_null_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsNullConcat de la función DATABASEPROPERTYEX.

NUMERIC_ROUNDABORT { ON | OFF }

  • ACTIVAR

    Se genera un error cuando se produce una pérdida de precisión en una expresión.

  • Apagado

    Las pérdidas de precisión no generan un mensaje de error y el resultado se redondea con la precisión de la columna o variable que lo almacena.

Importante

El valor de NUMERIC_ROUNDABORT debe ser OFF al crear o realizar cambios en índices de columnas calculadas o vistas indizadas.

Puede determinar el estado de esta opción en la columna is_numeric_roundabort_on de la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsNumericRoundAbortEnabled de la función DATABASEPROPERTYEX.

QUOTED_IDENTIFIER { ON | OFF }

  • ACTIVAR

    Las comillas dobles se pueden usar para identificadores delimitados.

    Todas las cadenas delimitadas por comillas dobles se interpretan como identificadores de objetos. Los identificadores entre comillas no tienen que adaptarse a las reglas de Transact-SQL para identificadores. Pueden ser palabras clave e incluir caracteres que no se permiten en los identificadores de Transact-SQL. Si una comilla doble (") forma parte del identificador, puede representarse entre dos comillas dobles ("").

  • Apagado

    Los identificadores no se pueden incluir entre comillas y deben seguir todas las reglas de Transact-SQL para los identificadores. Los literales se pueden delimitar con comillas simples o dobles.

SQL Server también permite delimitar los identificadores con corchetes ([ y ]). Los identificadores entre corchetes pueden usarse siempre, independientemente del valor de QUOTED_IDENTIFIER. Para obtener más información, consulte Identificadores de base de datos.

Al crear una tabla, la opción QUOTED IDENTIFIER siempre se almacena como ON en los metadatos de la tabla. La opción se almacena incluso si está establecida en OFF al crear la tabla.

La configuración en el nivel de conexión establecida mediante la instrucción SET invalida la configuración predeterminada de la base de datos para QUOTED_IDENTIFIER. De forma predeterminada, los clientes ODBC y OLE DB generan una instrucción SET en el nivel de conexión estableciendo QUOTED_IDENTIFIER en ON. Los clientes ejecutan la instrucción cuando se conecta a una instancia de SQL Server. Para más información, consulte SET QUOTED_IDENTIFIER.

Para determinar el estado de esta opción, examine la columna is_quoted_identifier_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsQuotedIdentifiersEnabled de la función DATABASEPROPERTYEX.

RECURSIVE_TRIGGERS { ON | OFF }

  • ACTIVAR

    Se permite la activación recursiva de desencadenadores AFTER.

  • Apagado

    Para determinar el estado de esta opción, examine la columna is_recursive_triggers_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsRecursiveTriggersEnabled de la función DATABASEPROPERTYEX.

    Nota:

    La recursividad directa solo se evita cuando RECURSIVE_TRIGGERS se establece en OFF. Para deshabilitar la recursividad indirecta, también debe establecer la opción de servidor desencadenadores anidados en 0.

Para determinar el estado de esta opción, examine la columna is_recursive_triggers_onde la vista de catálogo sys.databases o la propiedad IsRecursiveTriggersEnabled de la función DATABASEPROPERTYEX.

<target_recovery_time_option> ::=

target_recovery_time_option no se admite en Azure SQL Managed Instance.

Especifica la frecuencia de puntos de comprobación indirectos por base de datos. A partir de SQL Server 2016 (13.x), el valor predeterminado para las nuevas bases de datos es 1 minuto, que indica que la base de datos usa puntos de control indirectos. Para las versiones anteriores, el valor predeterminado es 0, que indica que la base de datos usa puntos de control automáticos, cuya frecuencia depende de la configuración del intervalo de recuperación de la instancia del servidor. Microsoft recomienda un minuto para la mayoría de los sistemas.

WITH <termination> ::=

Especifica el momento en que se revierten las transacciones incompletas cuando la base de datos pasa de un estado a otro. Si se omite la cláusula de terminación, la instrucción ALTER DATABASE espera indefinidamente a que se produzca un bloqueo en la base de datos. Solamente se puede especificar una cláusula de terminación y debe seguir a las cláusulas SET.

Nota:

No todas las opciones de base de datos usan la cláusula WITH <termination>. Para más información, consulte la tabla en "Opciones de configuración de la sección "Comentarios" de este artículo.

  • ROLLBACK AFTER integer [SECONDS] | ROLLBACK IMMEDIATE

    Especifica si la operación de reversión se ejecuta transcurrido un número de segundos determinado o de forma inmediata.

  • NO_WAIT

    Especifica que se produce un error en la solicitud si el estado de la base de datos o el cambio de opción solicitados no se pueden completar inmediatamente. Completarse inmediatamente significa que no se espera a que las transacciones se confirmen o reviertan por su cuenta.

<temporal_history_retention> ::=

Opciones de Set

Para recuperar la configuración actual de las opciones de base de datos, use la vista de catálogo sys.databases o DATABASEPROPERTYEX.

Una vez configurada una opción de la base de datos, la nueva configuración surte efecto de inmediato.

Puede cambiar los valores predeterminados de cualquiera de las opciones de las bases de datos recién creadas. Para ello, cambie la opción adecuada de base de datos del sistema model.

Ejemplos

A. Habilitación del aislamiento de instantáneas en una base de datos

En el siguiente ejemplo se habilita la opción del marco de aislamiento de instantánea para la base de datos AdventureWorks2022 .

USE master;
GO
ALTER DATABASE [database_name]
SET ALLOW_SNAPSHOT_ISOLATION ON;
GO
-- Check the state of the snapshot_isolation_framework
-- in the database.
SELECT name, snapshot_isolation_state,
    snapshot_isolation_state_desc AS description
FROM sys.databases
WHERE name = N'[database_name]';
GO

El conjunto de resultados muestra que el marco de aislamiento de instantánea está habilitado.

name snapshot_isolation_state description
[database_name] 1 ACTIVAR

B. Habilitación, modificación o deshabilitación del seguimiento de cambios

En el ejemplo siguiente se habilita el seguimiento de cambios para la base de datos AdventureWorks2022 y se establece el período de retención en 2 días.

ALTER DATABASE [database_name]
SET CHANGE_TRACKING = ON
(AUTO_CLEANUP = ON, CHANGE_RETENTION = 2 DAYS);

En el ejemplo siguiente se muestra cómo cambiar el período de retención a 3 días.

ALTER DATABASE [database_name]
SET CHANGE_TRACKING (CHANGE_RETENTION = 3 DAYS);

En el ejemplo siguiente se muestra cómo deshabilitar el seguimiento de cambios para la base de datos AdventureWorks2022 .

ALTER DATABASE [database_name]
SET CHANGE_TRACKING = OFF;

C. Habilitación del Almacén de consultas

En el ejemplo siguiente se habilita el Almacén de consultas y configura los parámetros del Almacén de consultas.

ALTER DATABASE [database_name]
SET QUERY_STORE = ON
    (
      OPERATION_MODE = READ_WRITE,
      CLEANUP_POLICY = ( STALE_QUERY_THRESHOLD_DAYS = 90 ),
      DATA_FLUSH_INTERVAL_SECONDS = 900,
      QUERY_CAPTURE_MODE = AUTO,
      MAX_STORAGE_SIZE_MB = 1024,
      INTERVAL_LENGTH_MINUTES = 60
    );

D. Habilitación del Almacén de consultas con estadísticas de espera

En el ejemplo siguiente se habilita el Almacén de consultas y configura sus parámetros.

ALTER DATABASE [database_name]
SET QUERY_STORE = ON
    (
      OPERATION_MODE = READ_WRITE,
      CLEANUP_POLICY = ( STALE_QUERY_THRESHOLD_DAYS = 90 ),
      DATA_FLUSH_INTERVAL_SECONDS = 900,
      MAX_STORAGE_SIZE_MB = 1024,
      INTERVAL_LENGTH_MINUTES = 60,
      SIZE_BASED_CLEANUP_MODE = AUTO,
      MAX_PLANS_PER_QUERY = 200,
      WAIT_STATS_CAPTURE_MODE = ON
    );

E. Habilitación del Almacén de consultas con las opciones de directiva de captura personalizadas

En el ejemplo siguiente se habilita el Almacén de consultas y configura sus parámetros.

ALTER DATABASE [database_name]
SET QUERY_STORE = ON
    (
      OPERATION_MODE = READ_WRITE,
      CLEANUP_POLICY = ( STALE_QUERY_THRESHOLD_DAYS = 90 ),
      DATA_FLUSH_INTERVAL_SECONDS = 900,
      MAX_STORAGE_SIZE_MB = 1024,
      INTERVAL_LENGTH_MINUTES = 60,
      SIZE_BASED_CLEANUP_MODE = AUTO,
      MAX_PLANS_PER_QUERY = 200,
      WAIT_STATS_CAPTURE_MODE = ON,
      QUERY_CAPTURE_MODE = CUSTOM,
      QUERY_CAPTURE_POLICY = (
        STALE_CAPTURE_POLICY_THRESHOLD = 24 HOURS,
        EXECUTION_COUNT = 30,
        TOTAL_COMPILE_CPU_TIME_MS = 1000,
        TOTAL_EXECUTION_CPU_TIME_MS = 100
      )
    );

* Azure Synapse
Analytics *
 

 

Azure Synapse Analytics

Sintaxis

ALTER DATABASE { database_name }
SET
{
    <optionspec> [ ,...n ]
}
;

<option_spec>::=
{
    <auto_option>
  | <db_encryption_option>
  | <query_store_options>
  | <result_set_caching>
  | <snapshot_option>
}
;

<auto_option> ::=
{
    AUTO_CREATE_STATISTICS { OFF | ON }
}

<db_encryption_option> ::=
{
    ENCRYPTION { ON | OFF }
}

<query_store_option> ::=
{
    QUERY_STORE { OFF | ON }
}

<result_set_caching_option> ::=
{
    RESULT_SET_CACHING { ON | OFF }
}

<snapshot_option> ::=
{
    READ_COMMITTED_SNAPSHOT { ON | OFF }
}

Argumentos

database_name

Nombre de la base de datos que se va a modificar.

<auto_option> ::=

Controla las opciones automáticas.

AUTO_CREATE_STATISTICS { ON | OFF }

  • ACTIVAR

    El optimizador de consultas crea estadísticas en columnas únicas de los predicados de consulta, según sea necesario, para mejorar los planes de consulta y el rendimiento de las consultas. Estas estadísticas de columna única se crean cuando el optimizador de consultas las compila. Las estadísticas de columna única solamente se crean en las columnas que ya no son la primera columna de un objeto de estadísticas existente.

    El valor predeterminado es ON. Recomendamos utilizar la configuración predeterminada para la mayoría de las bases de datos.

  • Apagado

    El optimizador de consultas no crea las estadísticas en columnas únicas de los predicados de consulta cuando compila las consultas. Establecer esta opción en OFF puede producir planes de consulta poco óptimos y un rendimiento degradado de las consultas.

Este comando debe ejecutarse mientras se está conectado a la base de datos de usuario.

Para determinar el estado de esta opción, examine la columna is_auto_create_stats_on en la vista de catálogo sys.databases. También puede determinar el estado si examina la propiedad IsAutoCreateStatistics de la función DATABASEPROPERTYEX.

Para más información, vea la sección "Uso de las opciones de estadísticas de toda la base de datos" de Estadísticas.

<db_encryption_option> ::=

Controla el estado del cifrado de la base de datos.

ENCRYPTION { ON | OFF }

  • ACTIVAR

    Establece la base de datos que se va a cifrar.

  • Apagado

    Establece la base de datos que no se va a cifrar.

Para más información sobre el cifrado de bases de datos, consulte cifrado de datos transparente (TDE)y Cifrado de datos transparente para Azure SQL Database, Azure SQL Managed Instance y Azure Synapse Analytics.

Cuando el cifrado está habilitado en el nivel de base de datos, todos los grupos de archivos se cifran. Los nuevos grupos de archivos heredan la propiedad cifrada. Si algún grupo de archivos de la base de datos se establece en READ ONLY, se produce un error en la operación de cifrado de la base de datos.

Puede ver el estado del cifrado de la base de datos, así como el estado del análisis de cifrado, mediante la vista de administración dinámica sys.dm_database_encryption_keys.

<query_store_option> ::=

Controla si el almacén de consultas está habilitado en este almacenamiento de datos.

QUERY_STORE { ON | OFF }

  • ACTIVAR

    Habilita el Almacén de consultas.

  • Apagado

    Deshabilita el Almacén de consultas. OFF Es el valor predeterminado.

Nota:

En Azure Synapse Analytics, debe ejecutar ALTER DATABASE SET QUERY_STORE desde la base de datos de usuario. No se admite la ejecución de la instrucción desde otra instancia de almacén de datos.

Nota:

Para Azure Synapse Analytics, el Almacén de consultas se puede habilitar como en otras plataformas, pero no se admiten opciones de configuración adicionales.

<result_set_caching_option> ::=

Se aplica a: Azure Synapse Analytics

Controla si el resultado de la consulta se almacena en caché en la base de datos.

RESULT_SET_CACHING { ON | OFF }

  • ACTIVAR

    Especifica que los conjuntos de resultados de consulta devueltos de esta base de datos se almacenan en caché en la base de datos.

  • Apagado

    Especifica que los conjuntos de resultados de consulta devueltos de esta base de datos no se almacenan en caché en la base de datos.

Este comando debe ejecutarse mientras se está conectado a la base de datos master. Los cambios realizados a esta configuración de base de datos se aplicarán inmediatamente. Los costos de almacenamiento se aplican mediante el almacenamiento en caché de conjuntos de resultados de consultas. Después de deshabilitar el almacenamiento en caché de resultados para una base de datos, la memoria caché de resultados persistente anteriormente se elimina inmediatamente del almacenamiento de Azure Synapse.

Ejecute este comando para comprobar la configuración del almacenamiento en caché del conjunto de resultados de una base de datos. Si el almacenamiento en caché del conjunto de resultados está activado, is_result_set_caching_on devuelve 1.

SELECT name, is_result_set_caching_on FROM sys.databases
WHERE name = <'Your_Database_Name'>

Ejecute este comando para comprobar si se ha ejecutado una consulta con un resultado en caché. La columna result_cache_hit devuelve 1 para el acierto de caché, 0 para errores de caché y valores negativos por motivos por los que no se usó el almacenamiento en caché del conjunto de resultados. Para más información, consulte sys.dm_pdw_exec_requests.

SELECT request_id, command, result_cache_hit FROM sys.dm_pdw_exec_requests
WHERE request_id = <'Your_Query_Request_ID'>

Nota:

El almacenamiento en caché del conjunto de resultados no se debe usar junto con DECRYPTBYKEY. Si se debe usar esta función criptográfica, asegúrese de que el almacenamiento en caché del conjunto de resultados está deshabilitado (en el nivel de sesión o en el nivel de base de datos) en el momento de la ejecución.

Importante

Las operaciones para crear la caché del conjunto de resultados y recuperar los datos de la caché se producen en el nodo de control de una instancia de almacenamiento de datos. Cuando se activa el almacenamiento en caché de conjuntos de resultados, la ejecución de consultas que devuelven un conjunto de resultados grande (por ejemplo, >1 millón de filas) puede provocar un uso intensivo de la CPU en el nodo de control y ralentizar la respuesta de consulta general en la instancia. Estas consultas se suelen usar durante la exploración de datos o las operaciones ETL. Para evitar el esfuerzo del nodo de control y los problemas de rendimiento, los usuarios deben desactivar el almacenamiento en caché de los conjuntos de resultados en la base de datos antes de ejecutar esos tipos de consultas.

Para obtener más información sobre la optimización del rendimiento con el almacenamiento en caché de conjuntos de resultados, consulte Guía de ajuste del rendimiento.

Permisos

Para establecer la opción RESULT_SET_CACHING, un usuario necesita un inicio de sesión principal de nivel de servidor (el que crea el proceso de aprovisionamiento), o bien ser miembro del rol de la base de datos de dbmanager.

<snapshot_option> ::=

Se aplica a: Azure Synapse Analytics

Controla el nivel de aislamiento de transacción de una base de datos.

READ_COMMITTED_SNAPSHOT { ON | OFF }

  • ACTIVAR

    Habilita la opción READ_COMMITTED_SNAPSHOT en el nivel de base de datos.

  • Apagado

    Desactiva la opción READ_COMMITTED_SNAPSHOT en el nivel de base de datos.

Este comando debe ejecutarse mientras se está conectado a la base de datos master. Al activar o desactivar READ_COMMITTED_SNAPSHOT para una base de datos de usuario, se matan todas las conexiones abiertas a esta base de datos. Debe realizar este cambio durante una ventana de mantenimiento de la base de datos o esperar hasta que no haya ninguna conexión activa a la base de datos, excepto la conexión que ejecuta el comando ALTER DATABASE. No es necesario que la base de datos esté en modo de usuario único. No se admite el cambio del valor READ_COMMITTED_SNAPSHOT en el nivel de sesión. Para verificar la configuración de la base de datos, compruebe la columna is_read_committed_snapshot_on en sys.databases.

En una base de datos con READ_COMMITTED_SNAPSHOT habilitada, las consultas pueden experimentar un rendimiento más lento debido al examen de versiones si hay varias versiones de datos presentes. Las transacciones de larga duración también pueden provocar un aumento del tamaño de la base de datos. Esta incidencia se produce si estas transacciones cambian los datos que bloquean la limpieza de la versión.

Permisos

Para establecer la opción READ_COMMITTED_SNAPSHOT, un usuario necesita el permiso ALTER en la base de datos.

Ejemplos

Comprobación de la configuración de estadísticas para una base de datos

SELECT name, is_auto_create_stats_on FROM sys.databases

Habilitar Almacén de consultas para una base de datos

ALTER DATABASE [database_name]
SET QUERY_STORE = ON;

Habilitación del almacenamiento en caché de conjuntos de resultados para una base de datos

-- Run this command when connecting to the MASTER database

ALTER DATABASE [database_name]
SET RESULT_SET_CACHING ON;

Comprobación de la configuración de almacenamiento en caché de conjuntos de resultados para una base de datos

SELECT name, is_result_set_caching_on
FROM sys.databases;

Habilitación de la opción Read_Committed_Snapshot para una base de datos

Ejecute este comando al conectarse a la base de datos master.

ALTER DATABASE MyDatabase
SET READ_COMMITTED_SNAPSHOT ON;

Microsoft Fabric

 

Microsoft Fabric

Use ALTER DATABASE ... SET para administrar microsoft Fabric Warehouse.

Sintaxis

-- Microsoft Fabric

ALTER DATABASE { warehouse_name | CURRENT }
SET
{
    <option_spec> [ ,...n ] 
}

<option_spec> ::=
{
    <data_lake_log_publishing>
  | <vorder>
}
;

<data_lake_log_publishing> ::=
{
    DATA_LAKE_LOG_PUBLISHING { PAUSED | AUTO }
}

<vorder> ::=
{
    VORDER = OFF
}

Comentarios

Actualmente, pausar la publicación de registros de Delta Lake y deshabilitar el comportamiento de pedido V en un almacenamiento son los únicos usos de ALTER DATABASE ... SET En Microsoft Fabric.

Permisos

El usuario debe ser miembro de los roles De administrador, miembro o colaborador en el área de trabajo tejido.

Ejemplos

A. Pausar la publicación de registros de Delta Lake

El siguiente comando de T-SQL pausa la publicación de registros de Delta Lake en el contexto de almacenamiento actual.

ALTER DATABASE CURRENT SET DATA_LAKE_LOG_PUBLISHING = PAUSED;

Para comprobar el estado actual de la publicación de registros de Delta Lake en todos los almacenes, del área de trabajo, use el siguiente código T-SQL para consultar sys.databases en una nueva ventana de consulta:

SELECT [name], [DATA_LAKE_LOG_PUBLISHING_DESC] FROM sys.databases;