Sistemi di risoluzione personalizzati basati su COM
I sistemi di risoluzione personalizzati offrono una flessibilità maggiore rispetto al meccanismo di risoluzione predefinito e possono implementare la logica di business richiesta dalle applicazioni che utilizzano i dati replicati. Un sistema di risoluzione personalizzato basato su COM è una libreria di collegamento dinamico (DLL, dynamic-link library) che implementa l'interfaccia COM ICustomResolver con i relativi metodi e proprietà e altre interfacce e definizioni di tipi di supporto progettate appositamente per la risoluzione dei conflitti.
Nota
Se possibile, è consigliabile utilizzare un gestore della logica di business anziché un sistema di risoluzione personalizzato basato su COM. Per ulteriori informazioni sui gestori della logica di business, vedere Esecuzione di logiche di business durante la sincronizzazione di tipo merge.
Per creare un sistema di risoluzione COM personalizzato, è possibile utilizzare la libreria dei tipi inclusa in replrec.dll. Per impostazione predefinita, questa libreria è installata in C:\Programmi\Microsoft SQL Server\100\COM.
Prima di creare un sistema di risoluzione COM personalizzato, è necessario stabilire i fattori seguenti:
I tipi di modifiche alle righe che si desidera risolvere, ad esempio le operazioni di aggiornamento, inserimento ed eliminazione oppure se il sistema di risoluzione deve essere richiamato durante le operazioni di caricamento o di download delle modifiche di tipo merge o durante entrambi i processi. È possibile specificare un tipo di modifica, tutte le modifiche o qualsiasi combinazione di modifiche. Il sistema di risoluzione dei conflitti del processo di merge predefinito gestisce tutti i conflitti non risolti da un sistema di risoluzione personalizzato.
Se utilizzare il rilevamento a livello di colonna per la risoluzione dei conflitti. Quando si utilizza il rilevamento a livello di colonna, vengono contrassegnati come conflitti solo i dati delle colonne in cui si verifica un conflitto. Negli altri casi i dati vengono uniti. I conflitti tuttavia vengono risolti in base alle stesse modalità utilizzate per il rilevamento a livello di riga, ovvero il processo che prevale sovrascrive l'intera riga di dati. I dati tuttavia possono essere una combinazione dei valori del server di pubblicazione e dei Sottoscrittori oppure valori alterati che non provengono né dal server di pubblicazione, né dai Sottoscrittori. Per ulteriori informazioni, vedere la sezione relativa al livello di rilevamento in Modalità di rilevamento e risoluzione dei conflitti da parte della replica di tipo merge.
Per implementare un sistema di risoluzione dei conflitti personalizzato basato su COM
- Programmazione della replica: Procedura: Implementazione di un sistema di risoluzione dei conflitti personalizzato basato su COM per un articolo di merge (programmazione della replica)
Un sistema di risoluzione personalizzato viene specificato per un articolo, non per un'intera pubblicazione. Lo stesso sistema può essere utilizzato con più articoli, ma la logica nei sistemi di risoluzione personalizzati è spesso specifica di una particolare tabella. Se la tabella utilizzata nell'articolo viene modificata dopo la creazione del sistema, ad esempio rinominando la colonna utilizzata nella risoluzione dei conflitti, potrebbe essere necessario modificare e ricompilare il sistema di risoluzione personalizzato.
Per specificare un sistema di risoluzione personalizzato
Microsoft SQL Server Management Studio: Procedura: Impostazione di un sistema di risoluzione dei conflitti dell'articolo di merge (SQL Server Management Studio)
Programmazione Transact-SQL della replica: Procedura: Impostazione di un sistema di risoluzione dei conflitti dell'articolo di merge (programmazione Transact-SQL della replica)