Sébastien Pertus
Introduction à Microsoft Synchronization Framework
Introduction au nouveau Framework de synchronisation .Net, déjà disponible dans Visual Studio 2008.
Par Sébastien Pertus publié le 02/12/2007 à 22:48
 
Pour réaliser un premier exemple de synchronisation, nous allons créer une application windows forms classique capable de récupérer une liste de clients d'une base de données SQL Serveur 2005.
Le projet représentant une application classique s'exécutant sur un poste nomade (ou non), il est crée sous le nom Client.
Pour les besoins de l'exemple, nous allons inclure une application appelée Tmp qui sera chargée d'insérer des éléments directement dans la base de données serveur, ce qui nous permettra de tester notre synchronisation.
La base de données à laquelle nous allons nous connecter contient une table de Customer, comme décrit dans le schéma suivant.
 
/content/8b9afe11-8131-47a5-971d-563e86a5bc4f/dbSyncExemple.JPG
 
Première étape : Rajouter une nouvel élément disponible dans Visual Studio 2008 : LocalDatabaseCache (extension .sync)
 
/content/8b9afe11-8131-47a5-971d-563e86a5bc4f/ItemLocalDatabaseCache.JPG
 
Un Wizard va se lancer et nous permettre de configurer notre espace de syncrhonisation
 
/content/8b9afe11-8131-47a5-971d-563e86a5bc4f/WizardSync01.JPG
 
Tout d'abord le wizard va nous créer un Fournisseur de synchronisation de type Sql Server CE. Pour cela, le wizard va même nous créer en local la base de donnée Sql Server CE, appelée SyncExemple.sdf.
Nous continuons les étapes de ce Wizard et nous spéficions les tables à synchroniser.
Dans notre cas, la table Customer.
Pour synchroniser, nous devons stocker les informations nécessaires à la récupération des données incrémentales.
Pour cela il est nécessaire de créer 2 colonnes supplémentaires dans notre base de données: LastEditDate et CreationDate
De plus, nous devons aussi tracer les lignes à supprimer. Pour ce faire, le wizard nous propose de créer une table temporaire qui stockera les lignes à supprimer lors de la synchronisation : Customer_Tombstone.
 
/content/8b9afe11-8131-47a5-971d-563e86a5bc4f/WizardSync02.JPG
 
Il ne reste plus qu'à créer un DataSet typé qui communiquera avec la base de données locale.
 
/content/8b9afe11-8131-47a5-971d-563e86a5bc4f/SyncBewiseDataSet.JPG
 
Notre configuration est terminée. Si on regarde les fichiers et référence du projet client, on peut remarquer :
De nouvelles références :
  1. Microsoft.Synchronization.Data
  2. Microsoft.Synchronization.Data.Server
  3. Microsoft.Synchronization.Data.SqlServerCe
Elles représentent l'ensemble des API permettant de créer des agents (SyncAgent) des providers serveur (DbServerSyncProvider) et des providers clients (SqlCeClientSyncProvider)
  1. System.Data.SqlServerCe
L'ensemble des API permettant de créer et se connecter à une base de données Sql Serveur Ce
Deux répertoires de scripts :
  • BewiseCache.Customer.sql : Les scripts de modifications de la base de données.
  • BewiseCache.Customer.undo.sql : Les scripts pour faire un RollBack.
4 nouveaux Fichiers :
  • app.config : Il contient les chaines de connexion aux deux bases de données.
  • BewiseCache : Notre wizard, qui contient en fait l'ensemble des classes de synchronisation.
  • SyncBewiseDataSet : Notre DataSet typé qui va communiquer directement avec la base de données locale.
 
/content/8b9afe11-8131-47a5-971d-563e86a5bc4f/Projet.JPG
 
Nous allons créer, comme nous avons toujours l'habitude, un formulaire, comprenant une datagrid et un ensemble de zones de saisie.
Je ne reviens pas sur l'utilisation des DataSources, vous connaissez déjà :)
Voici ce à quoi nous voulons arriver :
 
/content/8b9afe11-8131-47a5-971d-563e86a5bc4f/DesignerAppli.JPG
 
L'utilisation reste classique. La seule chose à retenir est que nous communiquons avec notre base de données locale et non pas avec le la base de données source.
Lors du premier lancement de l'application, les données sont déjà chargées dans la base de données locale, comme illustré dans la capture d'écran :
 
/content/8b9afe11-8131-47a5-971d-563e86a5bc4f/CaptureClient.jpg
 
Cette synchronisation a été réalisée par le designer BewiseSync.sync à la fin de sa configuration. Pratique pour commencer à travailler.
Notre projet fonctionne, nous pouvons insérer, modifier ou supprimer des lignes dans notre base de données locale.
Prochaine étape :
  • Synchronisation des données serveur
  • Synchronisation des données client

 Commentaires (5) - Introduction à Microsoft Synchronization Framework 

Discussion démarée par vega3000 le 05/12/2007 à 19:52 , 5 commentaire(s).

 Dernières Publications      

Windows Media Center et WCF : développez votre maison intelligente
  Le développement d'applications pour Windows Media Center est facilité avec l'arrivée du SDK 5.3. Même si l'on sent un modèle objet bien lourd derrière, il devient plus facile d'exposer les fonctionnalités de WMC sous la forme de services WCF.
par Frédéric Colin posté le 23/06/2008 à 08:04, lu 295 fois, #0
Notions avancées avec Biztalk Server 2006 R2
  Utilisation des notions d'interchange, corrélation et convoi avec BizTalk Server 2006 R2
par Kader Yildirim posté le 09/06/2008 à 08:04, lu 288 fois, #0
Lucene Persistence Engine pour Evaluant Universal Storage Services
  Suite à l'article de Laurent Kempé, voici un moteur de stockage pour EUSS permettant l'indexation d'entités métier avec Lucene.
par Nicolas Penin posté le 01/06/2008 à 23:38, lu 510 fois, #1
Tags: C#, Linq
XMLA Trivia : Découverte du XMLA
  Le XMLA (XML for Analysis) est un langage normalisé par plusieurs éditeurs BI pour simplifier l'accès aux données aux cubes et aux métadonnées des bases multidimensionnelles.
par Renaud Harduin posté le 25/05/2008 à 11:57, lu 523 fois, #0
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 1713 fois, #0
Comment manipuler simplement le contenu d'un fichier WordML ?
  Manipulations autour du format WordML
par Fabien Reinle posté le 14/05/2008 à 23:55, lu 781 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 1881 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 511 fois, #0

 Dernières Actualités      

Deep Earth – Une belle utilisation de Virtual Earth et de Silverlight Deep Zoom
  Ce projet très intéressant est disponible sur Codeplex et vous pouvez voir une démo sur la page suivante . Bien entendu comme touts les projets sur Codeplex vous avez accès aux sources....
Tags: Silverlight
Sortie de JetBrains ReSharper 4.0 en version finale, l’outil ultime pour Visual Studio
  Après plusieurs mois de Early Access Program (EAP) , JetBrains met enfin à disposition la version finale de son outil ReSharper 4.0 . Cette nouvelle version est disponible pour Visual Studio 2005 &...
Tags: Visual Studio 2008, Visual Studio 2005, Outils
BoutDuTunnel v1.4
  BoutDuTunnel est un petit logiciel de tunneling réseau écrit en C#. Il permet par exemple d’accéder aux services ftp/smtp/pop/telnet/nntp/… sur des réseaux qui n’autorisent...
BI Framework & sample sur CodePlex
  Après plusieurs demandes, je me suis décidé à déposer l'ensemble des sources et du BI Framework MS proposés dans mes articles sur codeplex : http://www.codeplex.com/BILAB Je le mettrais à jour au fil des...
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