IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Android Discussion :

Mise en place d'un systeme de mise à jour pour client android


Sujet :

Android

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    CEO
    Inscrit en
    Janvier 2005
    Messages
    18
    Détails du profil
    Informations personnelles :
    Localisation : Congo-Brazzaville

    Informations professionnelles :
    Activité : CEO

    Informations forums :
    Inscription : Janvier 2005
    Messages : 18
    Par défaut Mise en place d'un systeme de mise à jour pour client android
    Bonjour,

    je suis entrains de développer une application pour android, cette application a une base de données qui doit se synchronisée avec une base de donnée distant MySQL, j'ai crée les tables et j'ai ajouté un champ drapeau (boolean), si le drapeau est à false (valeur par défaut) c'est que la ligne n'est pas encore synchronisé avec la base de donnée embarquée (SQLite), une fois que l'application récupère (synchronisation) la ligne, il met le drapeau à true, avec un client ça marche sans problème mais comment gérer plusieurs clients android, par ce que si le premier client met le drapeau à true cela voudra dire que la base de donnée SQLite du premier client est synchro tandis que ce ne sera pas le cas des autres clients, bref voilà le soucis, en gros comment faire en sorte que chaque client synchronise sa base de donnée SQLite avec MySQL.

    Merci

  2. #2
    Expert confirmé

    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Février 2007
    Messages
    4 253
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Février 2007
    Messages : 4 253
    Billets dans le blog
    3
    Par défaut
    En général pour les synchronisations ce qu'on fait:

    1. On ne detruit jamais de données dans les tables. Les tables ont juste un "flag" "active" (ou deleted selon), et les requêtes ne s'appuient que sur les données actives. Au besoin (histoire de simplifier les requêtes) il est possible d'avoir une "vue" de la table.... Par exemple, j'ai une table "RAW_RESTAURANTS" avec le flag, et une view "RESTAURANTS" qui pointe sur les RAW_RESTAURANTS actifs.... mais bon... j'imagine que si vous faites de la synchronisation complète de table elle ne doit pas être très grosse, et par conséquent cela n'est pas forcément très interessant.

    2. On garde une colonne "LAST_MODIFICATION_DATE" ou "DATE_LAST_MODIFIED" qui correspond à la date de dernière modification des données. Cette colonne peut être remplie programmatiquement côté SQL, ou bien automatique (trigger). Cette date est aussi mise à jour en cas de création des données, ou de destruction (voir le flag ci-dessus).


    Côté client la synchro se fait simplement en calculant: select max(LAST_MODIFICATION_DATE) from XXXXXX (XXXX étant la table à synchroniser).
    On envoie ça à un "script" de synchro côté serveur (le "max" date)
    Le serveur fait de même... si il n'y a pas de différence entre les deux ou que la version côté client est plus "récente", c'est qu'aucune synchro n'est nécessaire (à noter que la "synchro" peut quand même se faire, mais aucune donnée ne sera retournée).
    Il faut retourner deux choses:
    * La liste des objets marqués "deleted" avec LAST_MODIFICATION_DATE > date reçue => c'est la liste des objets détruits depuis la dernière synchro. Seul l'ID est nécessaire.
    * Les objets non marqués "deleted" avec LAST_MODIFICATION_DATE > date reçue => c'est la liste des objets modifiés ou créés depuis la dernière synchro. Toutes les données sont nécessaires.

  3. #3
    Modérateur
    Avatar de dinobogan
    Homme Profil pro
    ingénieur
    Inscrit en
    Juin 2007
    Messages
    4 073
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France

    Informations professionnelles :
    Activité : ingénieur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2007
    Messages : 4 073
    Par défaut
    Tu peux mettre une date sur ta base centrale. Elle est mise à jour à chaque modification.
    Chaque client peut comparer la date de la ligne distante par rapport à sa ligne en local.

    Cependant, s'il n'y a pas beaucoup de lignes, tu pourrais envisager de récupérer toutes les données à chaque fois.
    Mais il y a tellement de techniques pour la synchronisation qu'il faudrait que tu expliques tes contraintes.

    EDIT : trop lent...
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java
    Que la force de la puissance soit avec le courage de ta sagesse.

Discussions similaires

  1. Mise en place d'un systeme de vote electronique
    Par NSUADI89 dans le forum Développement
    Réponses: 1
    Dernier message: 04/02/2013, 09h17
  2. mise en place d'un systeme de visioconference
    Par yayaa dans le forum Développement
    Réponses: 1
    Dernier message: 22/06/2010, 19h24
  3. Mise en place d'un systeme de workflow
    Par lesultan2007 dans le forum VB.NET
    Réponses: 0
    Dernier message: 07/01/2010, 08h43
  4. [Mise en place d'un systeme de HTTPS / HTTP ]
    Par Kaldyris dans le forum Sécurité
    Réponses: 0
    Dernier message: 29/12/2009, 10h49
  5. mise en place d'un systeme anti intrusion
    Par diallocefive dans le forum Réseau
    Réponses: 1
    Dernier message: 07/05/2009, 09h50

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo