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

Langage SQL Discussion :

Requête SQL dans le vb6


Sujet :

Langage SQL

  1. #1
    Membre averti
    Homme Profil pro
    Retraitè
    Inscrit en
    Février 2019
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Retraitè

    Informations forums :
    Inscription : Février 2019
    Messages : 24
    Par défaut Requête SQL dans le vb6
    Bonjour

    Si je ne me suis pas trompé de forum, je tiens â vous exposer mon probléme.
    J'une colonne de ma table ( access) comme BD , et travaille avec le VB6, où se un mot ( chaine ) se repéte plus de 2 fois. Et je voulais faire afficher ce mot dans le Combox ( liste déroulante)une seule fois, pour celà j'ai utilsè

    [Code]Sqls= "select distinct(Departement) from TableDepartement where ( Societe= '"& cstr(varsociete) &"')"[code]

    Avec ce code l"application me renvoie le mot 2 fois.

    Merci pour toute aide

  2. #2
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 637
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 637
    Billets dans le blog
    10
    Par défaut
    bonjour,

    Si la table est nommée comme il faut, il s'agit de la table des départements, dans ce cas
    - je ne vois pas comment le même département peut apparaître deux fois
    - le distinct ne sert à rien

    Si la table n'est pas celle des départements, expliquez la nature de son contenu

    Par ailleurs, si la variable varsociete est d'origine saisie attention aux injections SQL !
    Exemple de saisie "DEPT150 OR 1=1" ==> votre filtre sera toujours à "vrai"

  3. #3
    Membre averti
    Homme Profil pro
    Retraitè
    Inscrit en
    Février 2019
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Retraitè

    Informations forums :
    Inscription : Février 2019
    Messages : 24
    Par défaut Requête SQL dans le VB6
    Bonjour

    Je m'explique, dans ma TableDepartements il y a deux olonnes, la 1° est nommé "Departement" contient
    Comptabilité
    Production

    La 2° nommée "Tache" où on trouve, les tâches corresponantes au département
    Saisie des opérations
    Facturation
    Tresorerie
    Plantation
    Recolte
    Deserbage

    Ainsi la table se presente comme ci dessous

    Colonne Departement. Colonne Tache
    Comptabilité. Saisie des opéations
    Comptabilté. Facturation
    Comptabilité. Tresorerie
    Production. Plantation
    Production. Recolte
    Production. Deserbage

    L'idée est que sur la liste défilante (Combox Departement ) doit faire apparaitre 2 departements

    Comptabilite
    Production

    Et sur l'autre liste défilante ( Combox Tache) doit apparaitre , lors de la sélection du departement, seulement les tâches lui correspondantes

  4. #4
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 637
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 637
    Billets dans le blog
    10
    Par défaut
    Donc

    - la table est mal nommée, c'est une table issue d'une association du modèle conceptuel entre les types d'entité DEPARTEMENT d'une part et TACHE d'autre part
    un nom comme DEPT_TACHE serait plus approprié
    - dans une table associative comme celle ci, il ne devrait JAMAIS y avoir de libellé du département ou de la tache, mais seulement les identifiants, hérités comme "foreign key" des tables issues des types d'entité correspondantes
    - vous ne pouvez pas en l'état répondre à votre besoin, puisque vous souhaitez filtrer par société where ( Societe= '"& cstr(varsociete) &"')" alors qu'il n'y a pas de colonne société dans cette table
    - le risque d'injection SQL persiste

  5. #5
    Membre averti
    Homme Profil pro
    Retraitè
    Inscrit en
    Février 2019
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Retraitè

    Informations forums :
    Inscription : Février 2019
    Messages : 24
    Par défaut Requête SQL dans le VB6
    Re bonjour

    Pardon, comme je me suis focalisé sur les deux colonnes, j'ai omis par inattention de vous préciset que ma TableDepartements contient aussi une colonne nommée "Société"

  6. #6
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Par défaut
    Bonjour,

    Si vous avez des doublons malgré le DISTINCT, alors c'est que ce ne sont pas des doublons

    Vous devez avoir une différence entre les deux chaines, même infime (majuscule au lieu de minuscule, ou avec et sans accent), voire invisible (caractère non imprimable, différents types d'espace,...).

    Vérifiez l'équivalent binaire des deux chaines.

  7. #7
    Membre averti
    Homme Profil pro
    Retraitè
    Inscrit en
    Février 2019
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Retraitè

    Informations forums :
    Inscription : Février 2019
    Messages : 24
    Par défaut Requête SQL dans le VB6
    [/QUOTE]Re bonjour

    Vous avez totalement raison. J'ai une E à la fin de la chaîne concernée sans accent.

    Merci pour votre attention

Discussions similaires

  1. Projet VB v6 : utilisation de requête SQL dans mon code
    Par MITCH31 dans le forum VB 6 et antérieur
    Réponses: 4
    Dernier message: 27/10/2005, 15h02
  2. [MySQL] Problème de requêtes SQL dans un script
    Par Nefret dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 08/09/2005, 15h08
  3. récupérer le résultat d'une requête sql dans un edit
    Par bertrand_declerck dans le forum Bases de données
    Réponses: 3
    Dernier message: 28/07/2005, 14h07
  4. Problème requête SQL dans page ASP
    Par rocs dans le forum ASP
    Réponses: 14
    Dernier message: 26/07/2005, 15h38
  5. Problème de requète SQL dans un Requery
    Par Keraccess dans le forum Requêtes et SQL.
    Réponses: 7
    Dernier message: 22/10/2004, 14h58

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