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 :

Déterminer si un champ est une clé primaire


Sujet :

Bases de données Delphi

  1. #1
    Membre actif
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Décembre 2003
    Messages
    168
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux
    Secteur : Distribution

    Informations forums :
    Inscription : Décembre 2003
    Messages : 168
    Points : 213
    Points
    213
    Par défaut Déterminer si un champ est une clé primaire
    Bonjour,

    Est-il possible via un ttable ou tquery de savoir si un champ est la clé primaire
    et s'il peut être null ou pas ?

    Pour info j'utilise Delphi 7, comme base de données pour le moment sqlite3 avec le composant Aducom
    par la suite SQL, Firebird

  2. #2
    Rédacteur
    Avatar de Giovanny Temgoua
    Profil pro
    Étudiant
    Inscrit en
    Novembre 2003
    Messages
    3 830
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2003
    Messages : 3 830
    Points : 4 006
    Points
    4 006
    Par défaut
    Bonsoir,

    Je propose ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
     With table1 do 
     for i := 0 to IndexDefs.Count - 1 do begin
         if ixPrimary in IndexDefs.Items[i].Options then 
            //le champ est un index
         if ixUnique in IndexDefs.Items[i].Options then
           //le champ est unique
     end;

    ou recupérer les index dans une liste et vérifier si le champ que tu as s'y trouve :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ListBox1.Clear;
    Table1.GetIndexNames(ListBox1.Items);

  3. #3
    Membre actif
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Décembre 2003
    Messages
    168
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux
    Secteur : Distribution

    Informations forums :
    Inscription : Décembre 2003
    Messages : 168
    Points : 213
    Points
    213
    Par défaut
    bonsoir

    merci king Faiser cela semble fonctionner pour les autres bdd mais pas pour sqlite
    le composant asqlitetable n'a pas de propriété indexdefs

  4. #4
    Rédacteur
    Avatar de Giovanny Temgoua
    Profil pro
    Étudiant
    Inscrit en
    Novembre 2003
    Messages
    3 830
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2003
    Messages : 3 830
    Points : 4 006
    Points
    4 006
    Par défaut
    Désolé, je ne suis pas un utilisateur de SqlLite. Essaies de trouver des infos avec google (ou peut être un autre membre pourra te proposer quelque chose)

    A+

  5. #5
    Membre actif
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Décembre 2003
    Messages
    168
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux
    Secteur : Distribution

    Informations forums :
    Inscription : Décembre 2003
    Messages : 168
    Points : 213
    Points
    213
    Par défaut
    J'ai trouvé

    Avec le composant aducom il faut utiliser la méthode GetTableInfo du TASQLite3DB
    Elle demande en paramètre le nom de la table et un tlist
    En castant le TList avec un TASQLite3Field on a les propriétés

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    FieldName : String // Nom du champ
    FieldPK     : integer // si = 1 cle primaire
    FieldNN     : integer // si = 1 null non autorisé
    il y a aussi
    FieldType: string // type du champ
    FieldDefault: string // valeur par defaut
    [Balise code ajoutée par King Kaiser]

  6. #6
    Nouveau membre du Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2012
    Messages
    53
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2012
    Messages : 53
    Points : 39
    Points
    39
    Par défaut
    Petit déterrage !

    Je cherche à savoir si un champ ( parmi beaucoup ) est clé primaire et s'il est non null, à partir d'un ADOQuery et non d'une TTAble.
    J'ai beau tester tous les paramètres de Fields, je ne trouve pas.
    J'utilise déja :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ADOQuery.Fields[X].IsIndexField // Champs indexé ?
    ADOQuery.Fields[X].DataType = ftAutoInc // Champs autoincrémenté ?
    Avez vous une idée ?

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

Discussions similaires

  1. cle primaire avec plusieurs champs ?
    Par topolino dans le forum Administration
    Réponses: 12
    Dernier message: 29/04/2014, 10h29
  2. [MySQL] comment rendre un champs de type "date" autoincement alors qu'il est déjà primaire
    Par pierrot10 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 21/09/2010, 09h48
  3. cles primaire multi-champs dont un NULL
    Par mystikilla dans le forum PostgreSQL
    Réponses: 2
    Dernier message: 12/12/2008, 19h14
  4. valeur par defaut d'un champ cle primaire
    Par amne26 dans le forum IHM
    Réponses: 1
    Dernier message: 09/10/2008, 07h10
  5. Réponses: 17
    Dernier message: 25/04/2005, 10h49

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