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

C++Builder Discussion :

Ajouter les entr�es dans une combobox a partir requete sql


Sujet :

C++Builder

  1. #1
    Membre �clair�
    Profil pro
    Inscrit en
    D�cembre 2005
    Messages
    593
    D�tails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : D�cembre 2005
    Messages : 593
    Par d�faut Ajouter les entr�es dans une combobox a partir requete sql
    c'est encore moi..

    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    6
    7
    8
    genrechoisi=ComboBox1->Text;
    typechoisi=ComboBox2->Text;
    //ShowMessage (genrechoisi);
    //ShowMessage (typechoisi);
    SQLQuery1->Active=false;
    SQLQuery1->SQL->Clear();
    SQLQuery1->SQL->Add("SELECT * FROM `produits` where `Genres` LIKE 'genrechoisi' AND `Types` LIKE 'typechoisi'");
    SQLQuery1->Active=true;
    Donc je recupere la valeur choisie dans le combobox 1 et 2.
    Ensuite j'aimerais afficher le champ "Marques" de ma table suivant les criteres choisis dans les combobox 1 et 2.
    Je sais pas si il faut que j'utilise un DBCombobox ou si il est possible d'ajouter les valeurs comme ca.

    Merci d'avance

  2. #2
    Membre �m�rite
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    573
    D�tails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 573
    Par d�faut
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    genrechoisi=ComboBox1->Text;
    typechoisi=ComboBox2->Text;
    //ShowMessage (genrechoisi);
    //ShowMessage (typechoisi);
     
    AnsiString requete1 ;
    requete1 = "SELECT * FROM \`produits\` where \`Genres\` = ' ";
    requete1 = requete1 + genrechoisi.C_Str() ;
    requete1 = requete1 + "\'AND \`Types\` =\'";
    requete1 = requete1 + typechoisi.C_Str() ;
    requete1 = requete1 + "\'";
    Memo1->Lines->Add(requete1.C_Str()); // pour regarder la requete
    SQLQuery1->Active=false;
    SQLQuery1->SQL->Clear();
    SQLQuery1->SQL->Add(requete1.C_Str());
    SQLQuery1->Active=true;
    A peu de chose pres , �� doit etre ��

    Sinon , regardes cet exemple que j ai post� qui utilise l API SQL
    http://www.developpez.net/forums/sho...d.php?t=427567

  3. #3
    Membre �clair�
    Profil pro
    Inscrit en
    D�cembre 2005
    Messages
    593
    D�tails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : D�cembre 2005
    Messages : 593
    Par d�faut
    il m'indique comme erreur
    [BCC32 Erreur] Unit3.cpp(86): E2316 'C_Str' n'est pas un membre de 'AnsiString'
    Aussi ici je vois que tu affiche dans un memo est ce la meme manip pour le combobox ? cad Combobox1->Lines->Add(requete1.C_Str());

  4. #4
    Membre Expert
    Avatar de Crayon
    Inscrit en
    Avril 2005
    Messages
    1 811
    D�tails du profil
    Informations personnelles :
    Localisation : Autre

    Informations forums :
    Inscription : Avril 2005
    Messages : 1 811
    Par d�faut
    Essai en minuscule: c_str()

  5. #5
    Membre �m�rite
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    573
    D�tails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 573
    Par d�faut
    oui autant pour moi

    c est en minuscule


    sinon c est ��

    ComboBox1->Items->Add("abcdefg");

  6. #6
    Membre �clair�
    Profil pro
    Inscrit en
    D�cembre 2005
    Messages
    593
    D�tails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : D�cembre 2005
    Messages : 593
    Par d�faut
    ah oui en effet en minuscule ca passe mais bon la en fait il me stock ma requete sql dans un memo... hors j'aimerais qu'il m'affiche les resultat dans ma combobox3... Sinon ma requete sql de d�part marchais tout aussi bien

  7. #7
    Membre �clair�
    Profil pro
    Inscrit en
    D�cembre 2005
    Messages
    593
    D�tails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : D�cembre 2005
    Messages : 593
    Par d�faut
    Je reformule plus clairement ma question :

    Comment faire pour que :

    Je r�cupere tous mes champs "Model" qui correspondent a mes "Genres" et "Types" choisi via le combobox1 et combobox2

    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    SQLQuery1->SQL->Add("SELECT `Model` FROM `produits` where `Genres` LIKE 'genrechoisi' AND `Types` LIKE 'typechoisi'");
    SQLQuery1->Active=true;
    Je voudrais quil m'affiche tt les models disponible dans un combobox3.

    Merci

  8. #8
    Membre Expert
    Avatar de bakaneko
    Profil pro
    Inscrit en
    F�vrier 2004
    Messages
    1 268
    D�tails du profil
    Informations personnelles :
    �ge : 45
    Localisation : France

    Informations forums :
    Inscription : F�vrier 2004
    Messages : 1 268
    Par d�faut
    Il suffit de parcourir les enregistrements pr�sents dans ton Query et de les ajouter dans ton ComboBox :

    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    ComboBox->Items->Clear();
    int count = Query->RecordCount;
     
    for (int i = 0;i < count;i++)
    {
      ComboBox->Items->Add(Query->FieldByName(MonChamp)->AsString;
      Query->Next();
    }
    Tu peux �galement essayer de passer par un TDBComboBox. Dans ce cas l�, ton combobox sera directement li� � ta source de donn�es.

  9. #9
    Membre �clair�
    Profil pro
    Inscrit en
    D�cembre 2005
    Messages
    593
    D�tails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : D�cembre 2005
    Messages : 593
    Par d�faut
    Citation Envoy� par bakaneko Voir le message
    Tu peux �galement essayer de passer par un TDBComboBox. Dans ce cas l�, ton combobox sera directement li� � ta source de donn�es.
    Merci pour le compteur je voyais +- ce qu'il fallair faire mais le pondre en c pas evident. je vais le tester de suite.

    Sinon pour le DBCombobox j'y avais penser mais j'ai pas chercher plus loin que ca avait l'air plus compliqu�. Tu en pense quoi c'est mieux quel methode ?

    merci

  10. #10
    Membre �clair�
    Profil pro
    Inscrit en
    D�cembre 2005
    Messages
    593
    D�tails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : D�cembre 2005
    Messages : 593
    Par d�faut
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    ComboBox3->Items->Clear();
    SQLQuery1->SQL->Clear();
    SQLQuery1->SQL->Add("SELECT `Marques` FROM `produits` where `Genres` LIKE 'Femmes' AND `Types` LIKE 'Parfums'");
    int count = SQLQuery1->RecordCount;
    SQLQuery1->ExecSQL();
     
    for (int i = 0;i < count;i++)
    {
      ComboBox3->Items->Add(SQLQuery1->FieldByName["Marques"])->AsString;
      SQLQuery1->Next();
    }
    il me renvoi une erreur :

    [BCC32 Erreur] Unit3.cpp(95): E2235 Une fonction membre doit �tre appel�e ou son adresse prise
    Que dois je faire ?

  11. #11
    Membre �clair�
    Profil pro
    Inscrit en
    D�cembre 2005
    Messages
    593
    D�tails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : D�cembre 2005
    Messages : 593
    Par d�faut
    avec ce code il compile :

    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    genrechoisi=ComboBox1->Text;
    typechoisi=ComboBox2->Text;
    ShowMessage (genrechoisi);
    ShowMessage (typechoisi);
     
    ComboBox3->Items->Clear();
    SQLQuery1->SQL->Clear();
    SQLQuery1->SQL->Add("SELECT `Marques` FROM `produits` where `Genres` LIKE 'Femmes' AND `Types` LIKE 'Parfums 30ml'");
    int count = SQLQuery1->RecordCount;
    SQLQuery1->ExecSQL();
     
    for (int i = 0;i < count;i++)
    {
      ComboBox3->Items->Add("SQLQuery1->FieldByName[Marques]");
      SQLQuery1->Next();
     
    }
    qd je lance le programme apr�s il me marque une erreur :

    Exception d�clench�e � $7C812A7B. Classe d'exception EDatabaseError avec message 'SQLQuery1: Impossible d'effectuer cette op�ration sur un ensemble de donn�es ferm�'. Processus Project1.exe (2892)

  12. #12
    Membre Expert
    Avatar de bakaneko
    Profil pro
    Inscrit en
    F�vrier 2004
    Messages
    1 268
    D�tails du profil
    Informations personnelles :
    �ge : 45
    Localisation : France

    Informations forums :
    Inscription : F�vrier 2004
    Messages : 1 268
    Par d�faut
    Voici la correction de ton code

    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
     
    genrechoisi=ComboBox1->Text;
    typechoisi=ComboBox2->Text;
    ShowMessage (genrechoisi);
    ShowMessage (typechoisi);
     
    ComboBox3->Items->Clear();
    SQLQuery1->SQL->Clear();
    SQLQuery1->SQL->Add("SELECT Marques FROM produits where Genres LIKE 'Femmes' AND Types LIKE 'Parfums 30ml'");
    SQLQuery1->Open();//mieux vaut utiliser Open pour un SELECT que ExecSQL qui est plus réservé au INSERT/UPDATE
    int count = SQLQuery1->RecordCount;
     
    for (int i = 0;i < count;i++)
    {
      ComboBox3->Items->Add(SQLQuery1->FieldByName("Marques")->AsString);
      SQLQuery1->Next();
    }
    L'avantage du DBComboBox est que le contenu du ComboBox refl�te en permanence le r�sultat de ta requ�te. Donc, si tu r��xecutes ta requ�te, ton ComboBox sera mis en jour. En contre partie, je le trouve beaucoup moins souple.

  13. #13
    Membre �clair�
    Profil pro
    Inscrit en
    D�cembre 2005
    Messages
    593
    D�tails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : D�cembre 2005
    Messages : 593
    Par d�faut
    oki merci je testerais ca apres.

    POur ce qui est du DBCombobox qui refletera ma base de donn�es ce n'est pas un probleme vu que je dois dabord choisir le choix dans un combobox2( avec la valeurs de OnChange dans les evenement ) donc ma combobox3 sera bien mis a jour en temp voulu.

    Je testerais ton code cette aprem la je dois partir.

    Merci

  14. #14
    Membre �clair�
    Profil pro
    Inscrit en
    D�cembre 2005
    Messages
    593
    D�tails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : D�cembre 2005
    Messages : 593
    Par d�faut
    ca marche merci bien

    je passe en resolu

+ R�pondre � la discussion
Cette discussion est r�solue.

Discussions similaires

  1. R�ponses: 1
    Dernier message: 15/12/2013, 21h38
  2. [AC-2013] Ajout d'entr�e dans une table � partir d'une requ�te !
    Par KClaudel dans le forum VBA Access
    R�ponses: 4
    Dernier message: 26/07/2013, 15h59
  3. comment ajouter des donn�es et les enregister dans une combobox?
    Par mohtah2011 dans le forum Discussions diverses
    R�ponses: 1
    Dernier message: 24/06/2011, 19h56
  4. R�ponses: 4
    Dernier message: 10/12/2006, 16h47
  5. [vbexcel]Comment supprimer les doublons dans une combobox?
    Par Mugette dans le forum Macros et VBA Excel
    R�ponses: 20
    Dernier message: 24/11/2005, 11h12

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