Métodos de replicación incremental
Modificado en (lo más ideal)
El método de replicación Modified At
usa una columna datetime (que se rellena cuando se crea una fila y se actualiza cuando cambian los datos) para buscar los datos que se van a replicar. Este método está diseñado para trabajar con tablas que cumplan los siguientes criterios:
- contiene una columna
datetime
que se rellena inicialmente cuando se crea una fila y se actualiza cada vez que se modifica la fila; - la columna
datetime
nunca es nula; - las filas no se eliminan de la tabla
Además de esos criterios, el Adobe recomienda indexar la columna datetime
utilizada para la replicación Modified At
, ya que esto ayuda a optimizar la velocidad de replicación.
Cuando se ejecuta la actualización, los datos nuevos o modificados se identifican buscando filas que tengan un valor en la columna datetime
que se produjo después de la actualización más reciente. Cuando se detectan nuevas filas, se replican en la Data Warehouse. Si existen filas en el Administrador de Datas Warehouse, se sobrescribirán con los valores actuales de la base de datos.
Por ejemplo, una tabla puede tener una columna llamada modified\_at
que indica la última vez que se cambiaron los datos. Si la actualización más reciente se ejecutó el martes a mediodía, la actualización buscará todas las filas que tengan un valor de modified\_at
mayor que el martes a mediodía. Las filas detectadas que se hayan creado o modificado desde el mediodía del martes se replicarán en la Data Warehouse.
¿Lo sabías?
Aunque su base de datos no admita actualmente un método de replicación de Incremental
, es posible que pueda realizar cambios en su base de datos que permitan el uso de Modified At
o Single Auto Incrementing PK
.
Modified At
no solo es el método de replicación más ideal, sino también el más rápido. Este método no solo produce incrementos de velocidad notables con grandes conjuntos de datos, sino que tampoco requiere la configuración de una opción de nueva comprobación. Otros métodos deben iterar a través de una tabla completa para identificar los cambios, incluso si ha cambiado un pequeño subconjunto de datos. Modified At
se repite solamente en ese pequeño subconjunto.
Clave principal de incremento automático único
Auto Incrementing
es un comportamiento que asigna secuencialmente claves principales a las filas. Si una tabla es Auto Incrementing
y la clave principal más alta de la tabla es 1000, el siguiente valor principal es 1001 o superior. Una tabla que no usa el comportamiento Auto Incrementing
puede asignar un valor de clave principal inferior a 1000 o saltar a un número mucho mayor, pero no se usa a menudo.
Este método está diseñado para replicar nuevos datos de tablas que cumplan los siguientes criterios:
single-column primary key
; yprimary key
el tipo de datos esinteger
; yauto incrementing
valores de clave principal.
Cuando una tabla utiliza la replicación Single Auto Incrementing Primary Key
, se detectan nuevos datos buscando valores de clave principal superiores al valor más alto actual en la Data Warehouse. Por ejemplo, si el valor de clave principal más alto de la Data Warehouse es 500, cuando se ejecute la siguiente actualización, buscará filas con valores de clave principal 501 o superiores.
Añadir fecha
El método Add Date
funciona de manera similar al método Single Auto Incrementing Primary Key
. En lugar de utilizar un entero para la clave principal de la tabla, este método utiliza una columna timestamped
para buscar nuevas filas.
Cuando una tabla utiliza la replicación Add Date
, se detectan nuevos datos al buscar valores con marca de tiempo mayores que la última fecha sincronizada con la Data Warehouse. Por ejemplo, si una actualización se ejecutó por última vez el 20/12/2015 09:00:00, todas las filas con una marca de tiempo mayor que esta se marcarán como datos nuevos y se replicarán.
Modified At
, Add Date
no comprueba las filas existentes para obtener información actualizada, solo espera con interés las filas nuevas.Métodos de replicación de tabla completa
Tabla completa
La replicación Full table
actualiza toda la tabla cada vez que se detectan nuevas filas. Este es, con mucho, el método de replicación menos eficaz, ya que todos los datos deben volver a procesarse durante cada actualización, suponiendo que haya filas nuevas.
Las filas nuevas se detectan consultando la base de datos al principio del proceso de sincronización y contando el número de filas. Si la base de datos local contiene más filas que Commerce Intelligence, la tabla se actualiza. Si los recuentos de filas son idénticos o si Commerce Intelligence contiene más filas que la base de datos local, se omitirá la tabla.
Esto plantea el punto importante de que la replicación de Full Table
es incompatible cuando:
- se eliminan más filas que las creadas en la tabla de base de datos local entre ciclos de actualización subsiguientes, o
- los valores de columna cambian, pero no se crean filas adicionales
En cualquiera de las situaciones anteriores, la replicación de Full Table
no detecta ningún cambio y los datos quedan obsoletos. Debido a la ineficacia de este método de replicación y a los requisitos mencionados anteriormente, la replicación Full Table
solo se recomienda como último recurso.
Lote de clave principal
Cuando una tabla utiliza Primary Key Batch
(lote PK), se detectan nuevos datos contando las filas dentro de rangos, o lotes, de valores de clave principal. Aunque normalmente piensa que esto se utiliza con números enteros, incluso los valores de texto se pueden ordenar de una manera que permita al sistema definir intervalos constantes.
Por ejemplo, supongamos que se ejecuta una actualización y realiza un recuento de filas para el rango de claves de 1 a 100. En esta actualización, el sistema busca y registra 37 filas. En la siguiente actualización, se vuelve a realizar un recuento de filas en el intervalo 1-100 y se encuentran 41 filas. Dado que existe una diferencia en el número de filas en comparación con la última actualización, el sistema inspecciona ese rango (o lote) con más detalle.
Este método está diseñado para replicar datos de tablas que cumplan los siguientes criterios:
- columna única no entera; o
- claves compuestas (varias columnas que comprenden la clave principal): tenga en cuenta que las columnas utilizadas en una clave principal compuesta nunca pueden tener valores nulos; o
- valores de clave principal de una sola columna, enteros, sin aumento automático.
Este método no es ideal, ya que es increíblemente lento debido a la cantidad de procesamiento que debe ocurrir para examinar los lotes y encontrar cambios. El Adobe recomienda no utilizar este método a menos que sea imposible realizar las modificaciones necesarias para admitir los demás métodos de replicación. Espere que los tiempos de actualización aumenten si se debe utilizar este método.
Estableciendo métodos de replicación
Los métodos de replicación se establecen tabla por tabla. Para establecer un método de replicación para una tabla, necesita Admin
permisos para poder tener acceso al Administrador de Datas Warehouse.
-
Una vez en el Administrador de Datas Warehouse, seleccione la tabla de la lista
Synced Tables
para mostrar el esquema de la tabla. -
El método de replicación actual aparece debajo del nombre de la tabla. Para cambiarlo, haga clic en el vínculo.
-
En la ventana emergente que se muestra, haga clic en el botón de opción situado junto a
Incremental
oFull Table
replicación para seleccionar un tipo de replicación. -
A continuación, haga clic en el menú desplegable Replication Method para seleccionar un método. Por ejemplo,
Paused
oModified At
.NOTEAlgunos métodos incrementales requieren que establezca unReplication Key
. Commerce Intelligence usará esta clave para determinar dónde debe comenzar el siguiente ciclo de actualización.Por ejemplo, si desea utilizar el métodomodified at
para la tablaorders
, debe establecerdate column
como clave de replicación. Pueden existir varias opciones para las claves de replicación, pero usted seleccionacreated at
o la hora en que se creó el pedido. Si el último ciclo de actualización se detuvo el 1/12/2015 00:10:00, el siguiente ciclo comenzará a replicar datos con una fechacreated at
mayor que esta. -
Cuando termine, haga clic en Save.
Observe todo el proceso:
Ajuste
Para terminar, ha creado esta tabla que compara los distintos métodos de replicación. Es increíblemente práctico al seleccionar un método para las tablas de la Data Warehouse.
Method | Syncing New Data | Processing Rechecks on Large Data Sets | Handle Composite Keys? | Handle Non-Integer PKs? | Handle Non-Sequential PK Population? | Handle Row Deletion? |
---|---|---|---|---|---|---|
Auto-Incrementing Primary Key | Más rápido | Lento | No | No | No | Sí |
Primary Key Batch Monitoring | Lento | Lento | Sí | Sí | Sí | Sí |
Modified At | Más rápido | Más rápido | Sí | Sí | Sí | No |