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

Bases de données Delphi Discussion :

ClientDataSet.Refresh ne rafraichit pas les données


Sujet :

Bases de données Delphi

  1. #1
    Membre confirmé Avatar de WebPac
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    947
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 947
    Points : 512
    Points
    512
    Par défaut ClientDataSet.Refresh ne rafraichit pas les données
    Bonjour,

    tout mon problème est dans le titre, je fais un ClientDataSet.Refresh et il ne me retrouve pas les nouveaux enregistrements ou les valeurs modifiées des enregistrements existants.

    Il faut que je ferme l'application et la relance pour qu'il retrouve les modifications.

    Pire, si je ne fais pas de Refresh, l'application retrouve les enregistrements qu'elle a rajouté peu auparavant alors qu'avec le Refresh, elle ne les retrouve pas.

    Si les enregistrements ont été ajouté dans la BD vient une autre application, Refresh ou pas Refresh, le ClientDataSet ne les retrouve pas.

    Est-ce normal ? Fais-je quelquechose de mal ?

    Pour info, le State du ClientDataSet est à Browse. Chaque fois que je fais un Edit ou un Insert dans l'application, je fais un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
        Post;
        if ApplyUpdates( 0 ) > 0 then
        begin
          ShowMessage( 'Erreur pendant l''ApplyUpdate' );
          CancelUpdates;
        end;
    Mais je n'ai jamais le message d'erreur qui s'affiche.

  2. #2
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    Je crois qu'il faut que tu rafraichisses aussi la source des données de ton ClientDataSet puis après tu rafraichis ton ClientDataSet.
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

  3. #3
    Membre confirmé Avatar de WebPac
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    947
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 947
    Points : 512
    Points
    512
    Par défaut
    Citation Envoyé par Malatar
    Je crois qu'il faut que tu rafraichisses aussi la source des données de ton ClientDataSet puis après tu rafraichis ton ClientDataSet.
    Je vais peut-être dire une bêtise mais ce n'est pas grave, mais ce n'est pas mon ClientDataSet qui est justement ma source de données ?

  4. #4
    Expert éminent sénior
    Avatar de Cl@udius
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2006
    Messages
    4 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 4 878
    Points : 10 008
    Points
    10 008
    Par défaut
    Salut

    Citation Envoyé par WebPac
    mais ce n'est pas mon ClientDataSet qui est justement ma source de données ?
    Ton ClientDataSet est jeu d'enregistrements stocké en mémoire (c'est tout son intérêt d'ailleurs ^^). Celui-ci est alimenté au départ par une requête qui va elle chercher les données sur ton serveur.

    C'est donc cette requête qu'il faut initialement rafraîchir, puis ton ClientDataSet.
    C'est ce que voulais te préciser Malatar.

    @+ Claudius

  5. #5
    Membre confirmé Avatar de WebPac
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    947
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 947
    Points : 512
    Points
    512
    Par défaut
    En fouillant le code, c'est ce que j'ai cru comprendre en fait.
    C'est bizarre parce que le ClientDataSet est relié à un TSQLDataSet. Dans le code, le TSQLDataSet est activé, puis le ClientDataSet est activé (et désactive le SQLDataSet).
    Quand je faisais les tests, je le voyais le SQLDataSet inactif, donc je pensais que c'était un composant reliquat d'un ancien code qui ne servait plus.

    Ca marche maintenant, en activant le SQLDataSet, puis en le rafraichissant, puis en fermant le ClientDataSet, le rouvrant et le rafraichissant.
    Maintenant, je pense que tout n'est pas nécessaire, mais ça marche, donc je mets [Résolu] et je retire ce qui est inutile après.

    Merci.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Hibernate ne recharge pas les données
    Par CrazySeb dans le forum Hibernate
    Réponses: 2
    Dernier message: 21/07/2008, 13h57
  2. [MySQL] Tableau n'affiche pas les données sur les pages suivantes
    Par orleans dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 18/12/2007, 20h17
  3. Réponses: 1
    Dernier message: 11/09/2007, 17h06
  4. pb de syntaxe XML ne reconnais pas les données ..
    Par lolodelp dans le forum XML/XSL et SOAP
    Réponses: 1
    Dernier message: 19/06/2006, 11h24
  5. y'a pas les données quand je veux imprimer
    Par StyleXP dans le forum Bases de données
    Réponses: 38
    Dernier message: 25/03/2006, 19h15

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