Sébastien Pertus
Chapitre II : Synchronisation manuelle, personnalisation.
Après une introduction à Sync. Services for ADO.NET 2.0, nous allons construire aujourd'hui un ensemble de classes, sans passer par le designer, pour créer un système de synchronisation en nous appuyant sur Microsoft Synchronization Framework (MSF).
Par Sébastien Pertus publié le 13/01/2008 à 22:50
 
Pour commencer, nous devons bien savoir ce que nous devons créer.
Voici un schéma de l'architecture que nous devons reproduire :
 
/content/61a8af9e-e912-4557-b7c5-17e0734e14d7/SchemaGeneral.jpg
 
Et dans un soucis de compréhension (et pour préparer les prochains articles) je vais ici dissocier deux choses :
  1. Tout d'abord la partie "Serveur" : Il s'agit de l'ensemble des classes de synchronisation serveur, ainsi que les SyncAdapters , un pour chaque SyncTable.
    Nous verrons dans un prochain article que c'est cette partie, dans une architecture N-Tiers WCF, qui serait portée par notre service remote.
  2. La partie "Cliente" : Il s'agit de l'ensemble des classes de synchronisation de la source de données cliente et l'agent de synchronisation configuré avec les SyncTables.
    Dans notre architecture N-Tiers, il s'agirait ici de la partie embarquée dans le client.
Pour la partie Cliente, nous pouvons la représenter sous la forme :
 
/content/61a8af9e-e912-4557-b7c5-17e0734e14d7/SchemaClient.jpg
 
Nous avons notamment :
  1. Le Client Sync Provider : Nous connaissons déjà le fournisseur de synchronisation client, il s'agit du fournisseur de synchronisation Sql Ce, j'ai nommé SqlCeClientSyncProvider.
    Ce fournisseur de synchronisation dispose d'un ensemble de méthodes internes de création des tables, de requêtage incrémental et de stockage des métadatas nécessaires à notre synchronisation.
  2. Le SyncAgent : Il est le coordinateur de notre synchronisation. Il doit notamment connaitre le fournisseur de synchronisation client, le fournisseur de synchronisation serveur, ainsi que les tables à synchroniser.
  3. Les SyncTables : Il s'agit de l'ensemble des définitions des tables à synchroniser, plus les options de synchronisation (Direction, Création etc...). Ces SyncTables peuvent être liées dans un SyncGroup, conteneur garantissant un contexte de transaction ainsi qu'une mise à jour respectueuse des clés externes.
Pour la partie serveur, nous pouvons la représenter sous la forme :
 
/content/61a8af9e-e912-4557-b7c5-17e0734e14d7/SchemaServeur.jpg
 
Nous avons notamment :
  1. Le Server Sync Provider : Ce fournisseur de synchronisation serveur existe déjà, il s'agit du DbServerSyncProvider.
    Ce DbServerSyncProvider a l'avantage de pouvoir se connecter à n'importe quelle source de donnée de type ADO.NET; par contre il a les inconvénients de son avantage, il est à configurer entièrement, au contraire du provider client SqlCeClientSyncProvider, qui lui est déjà configuré, mais qui n'accède qu'à une source de type Sql Ce.
  2. Les SyncAdapters : On peut faire une comparaison du SyncAdapter avec le TableAdapter. Le SyncAdapter contient une commande permettant d'effectuer une opération (SQL) sur une source de données proposée par le DbServerSyncProvider.
    Chaque DbServerSyncProvider possède plusieurs SyncAdapters, un par table (enfin, par SyncTable !)
    Chaque SyncAdapter possède plusieurs commandes (DbCommand) lui permettant de requêter la source de données.
    La liste de ces commandes, au nombre de 8:
    • InsertCommand: Il s'agit de la commande permettant d'insérer les données coté serveur.
    • DeleteCommand: Il s'agit de la commande permettant de supprimer les données. Attention, il ne s'agit pas d'un "simple" Delete, cette commande doit savoir gérer les conflits, et forcer la suppression si nécessaire (cas où le client l'emporte lors du traitement du conflit).
    • UpdateCommand: Il s'agit de la commande permettant de mettre à jour les données. Comme la commande DeleteCommand, cette commande est soumise à la gestion des conflits et le forçage de la mise à jour.
    • SelectConflictDeletedRowsCommand: Lors d'un conflit, cette commande récupére les informations de la ligne supprimée côté serveur, pour nous permettre de gérer le conflit, et ordonner l'opération de forçage de la suppression ou non.
    • SelectConflictUpdatedRowsCommand: Lors d'un conflit, cette commande récupére les informations de la ligne mise à jour côté serveur, pour nous permettre de gérer le conflit, et ordonner l'opération de forçage de la mise à jour ou non.
    • SelectIncrementalInsertsCommand: Commande permettant de récupérer les nouveaux enregistrements insérés dans la source de données serveur depuis la dernière synchronisation
    • SelectConflictUpdatedRowsCommand: Commande permettant de récupérer les enregistrements mis à jour sur la source de données serveur depuis la dernière synchronisation
    • SelectIncrementalDeletesCommand: Commande permettant de récupérer les enregistrements supprimés de la source de données serveur depuis la dernière synchronisation
    Nous verrons dans la prochaine partie qu'il existe un objet, le SqlSyncAdapterBuilder, qui va nous permettre de générer l'ensemble des ces requêtes, pour chaque SqlSyncAdapter.

 Commentaires (3) - Chapitre II : Synchronisation manuelle, personnalisation. 

Discussion démarée par fcastell le 04/02/2008 à 09:53 , 3 commentaire(s).

 Dernières Publications      

Exploiter les données CSV via Linq en toute simplicité
  A partir du requêteur dynamique fourni en exemple avec Visual Studio 2008, nous allons essayer de remplir les propriétés d'un ensemble d'objets à partir des données d'un fichier CSV. Nous enrichirons aussi le parseur de nos propres fonctions.
par Frédéric Mélantois posté le 17/05/2008 à 11:41, lu 138 fois, #0
Polymorphisme et contrats de données WCF
  WCF aborde les types polymorphes du point de vue de la sérialisation. En effet, la connaissance du type réel potentiel est rendue nécessaire dès la description du contrat de données. Une fois n'est pas coutume, j'ai réalisé l'exemple en VB.NET.
par Frédéric Colin posté le 14/05/2008 à 08:40, lu 296 fois, #2
A la découverte de BizTalk Server 2006 3/3
  Développer un assembleur pour BizTalk Server 2006 R2
par Kader Yildirim posté le 06/05/2008 à 13:20, lu 147 fois, #0
Chapitre III : Sync Services for ADO.NET et WCF
   Suite des deux premiers chapitres sur la synchronisation avec Sync Services for ADO.NET, voici un nouvel article impliquant WCF dans une synchronisation déconnectée.
Requêtes dynamiques sur les IEnumerable
  A partir d'un exemple fourni avec Visual Studio 2008, initialement prévu pour tout objet Queryable, nous allons présenter comment en ajoutant très peu de code rendre disponible aux IEnumerable un requêteur dynamique.
par Frédéric Mélantois posté le 24/04/2008 à 15:03, lu 842 fois, #0
Développer une visionneuse d'images avec WPF et WCF
  Au travers de cet article, nous allons découvrir comment mettre en place une visionneuse d'images, grâce aux technologies WPF et WCF.
par Thomas Lebrun posté le 22/04/2008 à 22:46, lu 1004 fois, #2
LINQRoleProvider
  L'objectif de cet article est d'implémenter un fournisseur de rôles ASP.NET personnalisé à l'aide de LINQ To Sql tout en faisant un tour d'horizons de la syntaxe des requêtes LINQ.
par Antoine Griffard posté le 13/04/2008 à 22:18, lu 491 fois, #4
WCF : Transfert de messages streamés et sécurisation personnalisée
  Je poursuis ma série d'articles sur WCF en vous présentant cette fois-ci le mode de communication Streamé. Histoire d'aller un petit peu plus loin, j'ai protégé le service de manière personnalisée et utilisé un binding très courant : BasicHttpBinding
par Frédéric Colin posté le 07/04/2008 à 08:12, lu 883 fois, #0

 Dernières Actualités      

Injection de code et API de profiling .NET
  Si vous êtes intéressés par la sécurité du Framework, par le reverse engineering et la manipulation/injection de code .NET et les packers, alors jetez un coup d’œil...
NDepend pour l'analyse statique de code .NET
  Pour ceux qui ne connaissent pas NDepend , il s’agit d’un outil d’analyse statique de code .NET qui permet de remonter des informations à toute une équipe de développement. NDepend aide à travailler sur...
Tags: Outils
Microsoft met à disposition son IoC Container Unity 1.0 en version finale
  Microsoft met à disposition la version 1.0 de son IoC container Unity, sur CodePlex sous la forme d'un Application Block des Enterprise Library. Si vous voulez en savoir plus sur le sujet en .NET je vous...
Tags: Application Block
Microsoft MVP (Most Valuable Professional) sur Tech Head Brothers
  Je voudrais féliciter les nouveaux Microsoft MVP (Most Valuable Professional) du mois d'Avril 2008 qui publient sur Tech Head Brothers! Sans les auteurs le site ne serait rien. Sébastien Pertus - MVP SQL...
Les Webcasts des Microsoft TechDays 2008 sont en ligne
  Si vous avez participé ou non au Microsoft TechDays 2008 vous avez certainement manqué certaines présentation qui vous intéressaient. Voilà enfin votre chance de pouvoir suivre ces présentations en ligne...
Rapide résumé de la conférence MIX08
  La conférence MIX08 s'est achevée la semaine dernière avec peu d'annonces de nouvelles technologies (DeepZoom) mais surtout des releases de produits (et c'est pas un mal...). Nous avons donc eu droit aux...