REVISIÓN: La propiedad ANSI_NULLS de una vista indizada se cambia a FALSE después de que la vista indizada se replica la base de datos de suscripción en SQL Server 2008 o en SQL Server 2008 R2

Se aplica a: Microsoft SQL Server 2008 Service Pack 2SQL Server 2008 R2

Microsoft distribuye Microsoft SQL Server 2008 y Microsoft SQL Server 2008 R2 corrige como un archivo descargable. Como las revisiones son acumulativas, cada versión nueva contiene todas las revisiones y revisión de todas las revisiones de seguridad que se incluyeron con la anterior de SQL Server 2008 o SQL Server 2008 R2.

Síntomas


Imagine la siguiente situación:
  • Crear una publicación transaccional en Microsoft SQL Server 2008 o en Microsoft SQL Server 2008 R2.
  • Tiene una vista indizada. Establezca la propiedad ANSI_NULLS de la vista index en TRUE.
  • Agregar la vista indizada a la publicación de un artículo. Establecer el tipo de artículo "indizada view logbased". Nota: Puede utilizar el código siguiente para especificar el tipo de vista indizada. Hacerlo al ejecutar el procedimiento almacenado sp_addarticle para agregar el artículo de vista indizada a la publicación.
    @type = N'indexed view logbased'
  • Crear una suscripción para la publicación transaccional.
  • La vista indizada se replica la base de datos de suscripción.
En este escenario, se cambia la propiedad ANSI_NULLS de la vista indizada en FALSE en la base de datos de suscripción.Notas
  • Este problema normalmente se produce cuando la propiedad ANSI_NULLS de las tablas que intervienen en la estructura de la expresión SQL de la vista de índice se establece en FALSE.
  • Este problema también existe en Microsoft SQL Server 2005.

Causa


Este problema se produce porque las tablas, vistas, funciones y procedimientos almacenados en SQL Server 2008 comparten el mismo bit de almacenamiento de información para la propiedad ANSI_NULL . Por lo tanto, si la propiedad ANSI_NULLS de una de las tablas que intervienen en la estructura de la expresión SQL de la vista indizada se establece en FALSE, la propiedad ANSI_NULLS predeterminada para la vista indizada sería FALSE.

Solución


Información de actualización acumulativa

SQL Server 2008 Service Pack 1

La corrección para este problema se publicó en primer lugar en 10 de actualización acumulativa para SQL Server 2008 Service Pack 1. Para obtener más información acerca de este paquete de actualización acumulativa, haga clic en el número de artículo siguiente para verlo en Microsoft Knowledge Base:
2279604 Paquete de actualización acumulativa 10 para SQL Server 2008 Service Pack 1
Nota: Como las compilaciones son acumulativas, cada versión de corrección nueva contiene todas las revisiones y revisión de todas las revisiones de seguridad que se incluyeron con la anterior de SQL Server 2008. Microsoft recomienda que considere la posibilidad de aplicar la versión más reciente de revisión que contenga este hotfix. Si desea obtener más información, haga clic en el número de artículo siguiente para verlo en Microsoft Knowledge Base:
970365 Compilaciones de SQL Server 2008 que se publicaron después del lanzamiento de SQL Server 2008 Service Pack 1
Las revisiones de Microsoft SQL Server 2008 se crean para determinados service Pack de SQL Server. Debe aplicar un hotfix de SQL Server 2008 Service Pack 1 en una instalación de SQL Server 2008 Service Pack 1. De forma predeterminada, cualquier hotfix suministrada en un service pack de SQL Server se incluye en el próximo service pack de SQL Server.

SQL Server 2008 Service Pack 2

La corrección para este problema se publicó primero en la actualización acumulativa 1 para SQL Server 2008 Service Pack 2. Para obtener más información acerca de este paquete de actualización acumulativa, haga clic en el número de artículo siguiente para verlo en Microsoft Knowledge Base:
2289254 Actualización acumulativa 1 de SQL Server 2008 Service Pack 2
Nota: Como las compilaciones son acumulativas, cada versión de corrección nueva contiene todas las revisiones y revisión de todas las revisiones de seguridad que se incluyeron con la anterior de SQL Server 2008. Le recomendamos que considere aplicar la versión más reciente de revisión que contenga este hotfix. Si desea obtener más información, haga clic en el número de artículo siguiente para verlo en Microsoft Knowledge Base:
2402659 Compilaciones de SQL Server 2008 que se publicaron después del lanzamiento de SQL Server 2008 Service Pack 2

SQL Server 2008 R2

La corrección para este problema en primer lugar se publicó en la actualización acumulativa 4. Para obtener más información acerca de cómo obtener este paquete de actualización acumulativa para SQL Server 2008 R2, haga clic en el número de artículo siguiente para verlo en Microsoft Knowledge Base:
2345451 Paquete de actualización acumulativa 4 para SQL Server 2008 R2
Nota: Como las compilaciones son acumulativas, cada versión de corrección nueva contiene todas las revisiones y revisión de todas las revisiones de seguridad que se incluyeron con la anterior de SQL Server 2008 R2. Le recomendamos que considere aplicar la versión más reciente de revisión que contenga este hotfix. Si desea obtener más información, haga clic en el número de artículo siguiente para verlo en Microsoft Knowledge Base:
981356 Compilaciones de SQL Server 2008 R2 que se publicaron después del lanzamiento de SQL Server 2008 R2

Solución alternativa


Para evitar este problema, actualice la caché de metadatos después de crea la vista indizada, y antes de ejecutar sp_addarticle para agregar el artículo de vista indizada.Notas Para actualizar la caché de metadatos, utilice uno de los métodos siguientes:
  • Detenga el servicio SQL Server y, a continuación, inicie el servicio.
  • Establecer la base de datos de suscripciones sin conexión y, a continuación, establezca la base de datos en línea.

Estado


Microsoft ha confirmado que se trata de un problema de los productos de Microsoft recogidos en la sección "Se aplica a".

Referencias


Para obtener más información acerca del procedimiento almacenado sp_addarticle, visite el siguiente sitio Web de Microsoft:Para obtener más información acerca de cómo publicar datos y objetos de base de datos, visite el siguiente sitio Web de Microsoft:Para obtener más información sobre el modelo de servicio Incremental de SQL Server, haga clic en el número de artículo siguiente para verlo en Microsoft Knowledge Base:
935897 Un modelo de servicio Incremental está disponible desde el equipo de SQL Server para entregar revisiones para problemas detectados
Para obtener más información acerca del esquema de nomenclatura para las actualizaciones de SQL Server, haga clic en el número de artículo siguiente para verlo en Microsoft Knowledge Base:
822499Nuevo esquema de nomenclatura para los paquetes de actualización de software de Microsoft SQL Server
Para obtener más información acerca de la terminología de la actualización de software, haga clic en el número de artículo siguiente para verlo en Microsoft Knowledge Base:
824684 Descripción de la terminología estándar utilizada para describir las actualizaciones de software de Microsoft