Filtrar datos publicados

Se aplica a:SQL ServerAzure SQL Managed Instance

Filtrar artículos de tabla permite crear particiones de los datos que se van a publicar. Si filtra los datos publicados, podrá:

  • Minimizar la cantidad de datos que se envían a través de la red.

  • Reducir la cantidad de espacio de almacenamiento necesario en el suscriptor.

  • Personalizar las publicaciones y las aplicaciones en función de los requisitos de cada suscriptor.

  • Evitar o reducir los conflictos si los suscriptores actualizan datos, ya que pueden enviarse particiones de datos diferentes a varios suscriptores (dos suscriptores distintos no actualizarán los mismos valores de datos).

  • Evitar la transmisión de datos reservados. Se pueden utilizar filtros de fila y filtros de columna para restringir el acceso de un suscriptor a los datos. Para la replicación de mezcla, existen consideraciones de seguridad que se deben tener en cuenta si utiliza un filtro con parámetros que incluya HOST_NAME(). Para obtener más información, vea la sección sobre cómo filtrar con HOST_NAME() en el tema Parameterized Row Filters.

La replicación ofrece cuatro tipos de filtros:

  • Filtros de fila estáticos que están disponibles con todos los tipos de replicación.

    Mediante los filtros de fila estáticos, puede elegir un subconjunto de filas para publicarlo. Todos los suscriptores de una publicación filtrada reciben el mismo subconjunto de filas para la tabla filtrada. Para obtener más información, vea la sección "Filtros de fila estáticos" de este tema.

  • Filtros de columna que están disponibles con todos los tipos de replicación.

    Al utilizar los filtros de columna, puede elegir un subconjunto de columnas para publicarlo. Para obtener más información, vea la sección "Filtros de columna" de este tema.

  • Filtros de fila con parámetros que están disponibles solamente con la replicación de mezcla.

    Al utilizar los filtros de fila con parámetros, puede elegir un subconjunto de filas para publicarlo. A diferencia de los filtros estáticos que envían el mismo subconjunto de filas a cada suscriptor, los filtros de fila con parámetros utilizan un valor de datos suministrado por el suscriptor para enviar a los suscriptores diferentes subconjuntos de filas. Para obtener más información, consulte Filtros de fila con parámetros.

  • Filtros de combinación que están disponibles solamente con la replicación de mezcla.

    Al utilizar los filtros de combinación, puede ampliar un filtro de fila de una tabla publicada a otra. Para obtener más información, consulte Join Filters.

filtros de fila estáticos

En la siguiente ilustración se muestra una tabla publicada que está filtrada para que solamente se incluyan las filas 2, 3 y 6 en la publicación.

Row filtering

Un filtro de fila estático utiliza una sola cláusula WHERE para seleccionar los datos apropiados que se publicarán; se especifica la parte final de la cláusula WHERE. Considere la tabla Product en la base de datos de ejemplo AdventureWorks, que contiene la columna ProductLine. Para publicar solamente las filas con datos sobre los productos relacionados con las bicicletas de montaña, especifique ProductLine = 'M'.

Un filtro de fila estático produce un único conjunto de datos para cada publicación. En el ejemplo anterior, todos los suscriptores recibirían únicamente las filas con datos sobre productos relacionados con las bicicletas de montaña. Si tiene otro suscriptor que solamente requiera las filas con los datos sobre productos relacionados con bicicletas de paseo:

  • Con la replicación de instantáneas o la replicación transaccional, puede crear otra publicación e incluir la tabla en ambas publicaciones (en la cláusula del filtro para el artículo de dicha publicación, especifique ProductLine = 'R')).

    Nota:

    Los filtros de fila en las publicaciones transaccionales pueden producir una sobrecarga significativa porque la cláusula de filtro de artículos se evalúa para cada fila de registro escrita en una tabla publicada para determinar si la fila se debe replicar. Se deben evitar los filtros de fila en publicaciones transaccionales si cada nodo de replicación puede admitir la carga de datos completa y el conjunto de datos global es suficientemente pequeño.

  • Con la replicación de mezcla, utilice filtros de fila con parámetros en vez de crear varias publicaciones con filtros de fila estáticos. Para obtener más información, consulte Filtros de fila con parámetros.

Para definir o modificar un filtro de fila estático, vea Define and Modify a Static Row Filter.

Filtros de columnas

En la siguiente ilustración se muestra una publicación que filtra la columna C.

Column filtering

También puede utilizar conjuntamente el filtrado de filas y columnas, como se ilustra a continuación.

Row and column filtering

Tras crear una publicación, puede utilizar un filtro de columna para quitar una columna de una publicación existente, pero conservar la columna en la tabla en el publicador e incluir también una columna existente en la publicación. Para otros cambios, tales como agregar una columna nueva a una tabla y después agregarla al artículo publicado, utilice la replicación de cambios de esquema. Para más información, vea las secciones “Agregar columnas” y “Quitar columnas” del tema Realizar cambios de esquema en bases de datos de publicaciones.

Los tipos de columnas enumerados en la siguiente tabla no se pueden eliminar de ciertos tipos de publicaciones.

Tipo de columna Tipo de publicación y opciones
Columna de clave principal Las columnas de clave principal son necesarias para todas las tablas en las publicaciones transaccionales. Las claves principales no son necesarias para las tablas en publicaciones de combinación, pero si hay una columna de clave principal, ésta no se puede filtrar.
Columna de clave externa Todas las publicaciones creadas mediante el Asistente para nueva aplicación. Puede filtrar columnas de clave externa mediante procedimientos almacenados de Transact-SQL. Para obtener más información, vea Define and Modify a Column Filter.
Columna rowguid Publicaciones de combinación*
Columna msrepl_tran_version Publicaciones de instantáneas o transaccionales que permiten suscripciones actualizables
Columnas que no permiten valores NULL y no tienen valores predeterminados ni el conjunto de propiedades IDENTITY. Publicaciones de instantáneas o transaccionales que permiten suscripciones actualizables
Columnas con restricciones UNIQUE o índices Publicaciones de instantáneas o transaccionales que permiten suscripciones actualizables
Todas las columnas en una publicación de combinación de SQL Server 7.0 Las columnas no se pueden filtrar en las publicaciones de combinación de SQL Server 7.0.
Marca de tiempo Publicaciones de instantáneas o transaccionales de SQL Server 7.0 que permiten suscripciones actualizables

* Si va a publicar una tabla en una publicación de combinación y dicha tabla ya contiene una columna del tipo de datos uniqueidentifier con el conjunto de propiedades ROWGUIDCOL, la replicación puede utilizar dicha columna, en vez de crear una columna adicional denominada rowguid. En este caso, se debe publicar la columna existente.

Para definir o modificar un filtro de columna, vea Define and Modify a Column Filter.

Consideraciones de filtrado

Tenga en cuenta las siguientes consideraciones al filtrar datos:

  • Todas las columnas a las que se hace referencia en filtros de fila se deben incluir en la publicación. Es decir, no puede utilizar un filtro de columna para excluir una columna utilizada en un filtro de fila.

  • Si se agrega o cambia un filtro después de que se hayan inicializado las suscripciones, éstas deben reinicializarse.

  • El número máximo de bytes permitido en una columna utilizada en un filtro es de 1024 para un artículo en una publicación de combinación y 8000 en un artículo de una publicación transaccional.

  • En filtros de fila o filtros de combinación no se puede hacer referencia a columnas con los siguientes tipos de datos:

    • varchar(max) y nvarchar(max)

    • varbinary(máx)

    • text y ntext

    • image

    • XML

    • UDT

  • La replicación transaccional le permite replicar una vista indizada como vista o como tabla. Si replica la vista como tabla, no podrá filtrar columnas de la tabla.

Los filtros de fila no están diseñados para funcionar entre bases de datos. SQL Server restringe intencionadamente la ejecución de sp_replcmds (que filtra la ejecución debajo) al propietario de la base de datos (dbo). El dbo no tiene privilegios entre bases de datos. Con la incorporación de CDC (captura de datos modificados) en SQL Server 2008 (10.0.x), la lógica de sp_replcmds rellena las tablas de seguimiento de cambios con información a la que el usuario puede volver y que puede consultar. Por razones de seguridad, SQL Server restringe la ejecución de esta lógica de modo que un dbo malintencionado no pueda asaltar esta ruta de ejecución. Por ejemplo, un dbo malintencionado podría agregar desencadenadores a las tablas de CDC que se ejecutarían en el contexto del usuario que llama a sp_replcmds, en este caso el agente del lector de registros. Si la cuenta bajo la que se está ejecutando el agente tiene privilegios mayores, el dbo malintencionado podría escalar sus privilegios.

Consulte también

Publicar datos y objetos de base de datos