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.
Première étape : Rajouter une nouvel élément disponible dans Visual Studio 2008 : LocalDatabaseCache (extension .sync)
Un Wizard va se lancer et nous permettre de configurer notre espace de syncrhonisation
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.
Il ne reste plus qu'à créer un DataSet typé qui communiquera avec la base de données locale.
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 :- Microsoft.Synchronization.Data
- Microsoft.Synchronization.Data.Server
- 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)
- 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.
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 :
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 :
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