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

Composants VCL Delphi Discussion :

TDBGrid : ajouter une colonne non liée à un champ


Sujet :

Composants VCL Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2006
    Messages : 45
    Par défaut TDBGrid : ajouter une colonne non liée à un champ
    Bonjour,

    J'ai un petit problème que je suppose être bête et simple à résoudre, mais je ne trouve pas.

    Je voudrais ajouter 3 colonnes avec cases à cocher (Boolean) non liée à un champ dans un TDBGrid.

    Ces 3 colonnes devraient permettre d'effectuer des actions (en fonction des cases cochées) sur les enregistrements "sélectionnés".

    J'ai bien essayé avec des champs calculés, mais c'est logique, ça ne marche pas.

    Ma question est donc :
    Est-il possible d'ajouter des colonnes dans un TDBGrid non liées à un champs.
    Et si oui, comment ?

    Si quelqu'un sait comment faire ou a une autre idée pour arriver au même résultat, je lui serai reconnaisant à vie.

    Merci d'avance pour toutes vos idées.

  2. #2
    Membre averti
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2006
    Messages : 45
    Par défaut
    PS: En fait j'utilise un composant TDBGridEH de EHLib, mais ça ne change rien à la base.

  3. #3
    Expert confirmé
    Avatar de Ph. B.
    Homme Profil pro
    Freelance
    Inscrit en
    Avril 2002
    Messages
    1 786
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : France, Haute Garonne (Midi Pyrénées)

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

    Informations forums :
    Inscription : Avril 2002
    Messages : 1 786
    Par défaut
    Utilisez un ClientDataSet avec des champs "calculés internes"
    Propriété FieldKind initialisée à fkInternalCalc.
    --
    Philippe.

  4. #4
    Membre éclairé Avatar de liazidf
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations forums :
    Inscription : Mai 2002
    Messages : 281
    Par défaut
    Bonsoir,
    Vous pouvez ajouter dans la propriété Columns autant de champs que vous voulez.

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2006
    Messages : 45
    Par défaut
    Citation Envoyé par liazidf Voir le message
    Bonsoir,
    Vous pouvez ajouter dans la propriété Columns autant de champs que vous voulez.
    Merci aussi pour votre réponse, mais le problème n'est pas d'ajouter des colonnes liées à des champs, mais justement d'en ajouter non liées à un champ.

    Et tant qu'elles ne sont pas liées à un champ, elles ne peuvent-être modifiées.

  6. #6
    Membre expérimenté

    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    249
    Détails du profil
    Informations personnelles :
    Âge : 57
    Localisation : France, Marne (Champagne Ardenne)

    Informations forums :
    Inscription : Novembre 2006
    Messages : 249
    Par défaut
    Utiliser une base locale ne t'empeche pas d'utiliser un clientDataset.

    Comme tu le dis les colonnes non liées ne peuvent être modifiées dans le dbgrid, donc les colonnes à modifier doivent faire partie du dataset lié au datagrid.

    C'est donc effectivement la solution, sauf à utiliser des composants tiers

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2006
    Messages : 45
    Par défaut
    Citation Envoyé par Ph. B. Voir le message
    Utilisez un ClientDataSet avec des champs "calculés internes"
    Propriété FieldKind initialisée à fkInternalCalc.
    --
    Philippe.

    Merci pour votre réponse.

    l'application fonctionne en mode terminal service et la connexion à la DB est directe (Dataset -> Database).

    Le serveur Firebird tourne donc sur le même ordi que l'application.

    Je vais essayer cette solution à partir d'un Dataset (FIB+), mais j'ai des doutes.

  8. #8
    Expert confirmé
    Avatar de Ph. B.
    Homme Profil pro
    Freelance
    Inscrit en
    Avril 2002
    Messages
    1 786
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : France, Haute Garonne (Midi Pyrénées)

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

    Informations forums :
    Inscription : Avril 2002
    Messages : 1 786
    Par défaut
    Citation Envoyé par ALSCO Voir le message
    l'application fonctionne en mode terminal service et la connexion à la DB est directe (Dataset -> Database).

    Le serveur Firebird tourne donc sur le même ordi que l'application.
    Ce contexte n'est absolument pas génant.
    Votre application utilisera les composants comme suit
    ClientDataset -> DataProvider -> DataSet -> Database

  9. #9
    Membre averti
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2006
    Messages : 45
    Par défaut


    Impecable, ça fonctionne.

    Merci à tous pour votre aide et plus particulièrement à Philippe.

    Vous me retirez une grosse épine du pied.

    Alain.

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

Discussions similaires

  1. Réponses: 5
    Dernier message: 05/08/2013, 12h19
  2. [AC-2007] Affichage et Maj d'un champ via champs d'une table non liée
    Par Dimephis dans le forum Access
    Réponses: 7
    Dernier message: 22/12/2011, 12h24
  3. Réponses: 2
    Dernier message: 19/04/2011, 17h15
  4. Réponses: 2
    Dernier message: 14/11/2009, 22h35
  5. [ADO.Net][VB.NET] Comment ajouter une colonne Integer à un DataTable ?
    Par graphicsxp dans le forum Accès aux données
    Réponses: 2
    Dernier message: 20/04/2005, 12h08

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