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 :

TFDDataset 'déconnecté' en mode visualisation


Sujet :

Bases de données Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert Avatar de philnext
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    1 553
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 1 553
    Par défaut TFDDataset 'déconnecté' en mode visualisation
    Bonjour
    J'utilise classiquement des TFDQuery connectés à une base de données pour les utiliser avec une TDBGrid.
    Tout est OK mais j'aurais parfois besoin de déconnecter ce TFDQuery tout en conservant les données dans le TDBGrid, juste en visualisation, avec bien sûr la perte de certaines fonctions liées à la mise à jour des données mais ça ne me pose pas de pb.
    Il me semble que c'était possible avec l'ancienne library 'ADODB' voir : http://etutorials.org/Programming/ma...ed+Recordsets/
    Hélas je n'ai pas trouvé comment faire avec les composants Firedac (hormis faire une copie dans une TFDMemTable mais c'est un peu lourd).
    Quelqu'un a déjà mis en place ce principe ?

  2. #2
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 658
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 658
    Billets dans le blog
    65
    Par défaut
    Bonjour,

    S'il s'agit de FMX c'est toute la différence (si l'on excepte les colonnes mémo) entre StringGrid et Grid.
    Voilà une petite expérience
    Nom : Capture.PNG
Affichages : 384
Taille : 31,1 Ko
    et son code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    procedure TForm4.Button1Click(Sender: TObject);
    begin
    FDQuery1.DisableControls;
    FDQuery1.Close;
    end;
    La stringgrid contient toujours les données, la grid ne contiendra, après utilisation du bouton que les données des quelques lignes affichées (et encore n'est-ce que temporaire)

    J'avoue ne pas avoir encore fait le test en VCL mais cela va venir, curiosité quand tu me tiens !

    Hélas je n'ai pas trouvé comment faire avec les composants Firedac (hormis faire une copie dans une TFDMemTable mais c'est un peu lourd).
    une seule instruction c'est lourd ?

  3. #3
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 658
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 658
    Billets dans le blog
    65
    Par défaut
    Pour VCL, oui, j'ai testé. Je "triche éhontément" en utilisant Livebindings ce qui me permet de ne pas avoir à coder le remplissage de la TStringGrid
    Nom : Capture.PNG
Affichages : 387
Taille : 31,5 Ko
    et j'en arrive à la même conclusion.

    Bien sûr, il y a quelques "pertes" comme la colonne 0 de la DBGrid (colonne qui n'existe d'ailleurs plus en FMX)

    Cela étant je ne sais si ces solutions sont acceptables ?

  4. #4
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 658
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 658
    Billets dans le blog
    65
    Par défaut
    Citation Envoyé par SergioMaster Voir le message
    une seule instruction c'est lourd ?
    désolé, je n'ai pas tenu compte du changement du datasource donc deux instructions
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    procedure TForm4.Button1Click(Sender: TObject);
    begin
    FDMemtable1.CloneCursor(fdquery1,true);
    FDQuery1.DisableControls;
    DataSource1.DataSet:=fdmemtable1;
    FDQuery1.Close;
    end;

  5. #5
    Membre Expert Avatar de philnext
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    1 553
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 1 553
    Par défaut TFDDataset 'déconnecté' en mode visualisation
    @SergioMaster
    Merci pour ces réponses exhaustives, bon je vois que ma demande est un peu incomplète.
    Effectivement j'utilise une DBGrid donc du VCL, sans rentrer dans les détails le fonctionnement TDataset(ici un TFDQuery) <> TDBGrid m'intéresse car j'utilise pas mal de fonction interne aux TFDDataset (tri, cumuls..) mais qui n'ont pas besoin de la connexion.
    Certes je pourrais faire ce qui est fait avec la Grid FMX mais c'est un peu lourd, je peux aussi copier mon TFDQuery dans un TFDMemTable (ce que je fais dans certains cas, amis pour des tables importantes c'est lourd en perf et en conso. mémoire) mais je pensais qu'il existait un moyen de simplement déconnecter la TConnection.

  6. #6
    Membre Expert Avatar de philnext
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    1 553
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 1 553
    Par défaut
    Bon après différentes recherches ça existe en natif c'est la fonction Offline

    Avec au préalable les paramètres :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
      FDQueryLocal.FetchOptions.Mode := fmAll;
      FDQueryLocal.FetchOptions.AutoClose := True;

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

Discussions similaires

  1. [Vxi3] Affichage RéponseUtilisateur() en mode visualisation
    Par popiflo91 dans le forum Webi
    Réponses: 0
    Dernier message: 13/07/2012, 16h25
  2. Réponses: 3
    Dernier message: 30/08/2011, 15h52
  3. Réponses: 4
    Dernier message: 11/05/2006, 16h57
  4. [Vb.net][Ado.net] mode déconnecté avec sql
    Par hoummass dans le forum Accès aux données
    Réponses: 6
    Dernier message: 27/11/2005, 15h10

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