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 :

Traduire ce bout de code Delphi


Sujet :

C++Builder

  1. #1
    Membre �clair� Avatar de SmileSoft
    Inscrit en
    Mars 2008
    Messages
    436
    D�tails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 436
    Par d�faut Traduire ce bout de code Delphi
    Bonjour,

    j'ai un petit bout de code que je n'arrive pas � tous traduire en c++ Builder.
    je mets en commentaire les instructions que j'ai pu traduire � l'aveuglette mais �a n'a pas march�!
    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
    18
    19
     
    function NouvelID(Table, Clef: String): Integer;
    // int NouvelID(TTable Table, String Clef) 
    begin
     
      with SQLRequeteID do //SQLRequeteID étant le nom du composant TQury 
      begin
        Close;
        SQL.Clear; 
    //SQLRequeteID->SQL->Clear();
        SQL.Add('select max(' + Clef + ') from ' + Table);
    //SQLRequeteID->SQL->Add('select max(' + Clef + ') from ' + Table);
        ExecQuery;
    //SQLRequeteID->ExecSQL();
        Result := Fields[0].AsInteger + 1;
    //Result = Fields[0]->AsInteger + 1;
        Close;
      end;
    end;

    est ce que vous pouvez m'aider l� dessus ?

    Merci d'avance

  2. #2
    Membre Expert
    Avatar de sat83
    Homme Profil pro
    D�veloppeur informatique
    Inscrit en
    Mars 2004
    Messages
    1 040
    D�tails du profil
    Informations personnelles :
    Sexe : Homme
    �ge : 41
    Localisation : France, Haut Rhin (Alsace)

    Informations professionnelles :
    Activit� : D�veloppeur informatique

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 040
    Par d�faut
    Code pascal : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    function NouvelID(Table, Clef: String): Integer;
    begin
      with SQLRequeteID do //ici SQLRequeteID  n'est pas un TQUery
      begin
        Close;
        SQL.Clear; 
        SQL.Add('select max(' + Clef + ') from ' + Table);
        ExecQuery;
        Result := Fields[0].AsInteger + 1;
        Close;
      end;
    end;

    Ce qui donne en utilisant un TQuery:

    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    int NouvelID(AnsiString Table, AnsiString Clef)
    {
     
        SQLRequeteID->Close(); // ou SQLRequeteID->Active = false;
        SQLRequeteID->SQL->Clear(); 
        SQLRequeteID->SQL->Add("select max(" + Clef + ") as MAX_VALUE from " + Table );
        SQLRequeteID->Open(); // ou SQLRequeteID->Active = true;
        int result = SQLRequeteID->FieldByName( "MAX_VALUE")->AsInteger + 1;
        SQLRequeteID->Close(); // ou SQLRequeteID->Active = false;
        return( result ) ;
    }
    J'ai pas BCB sous la main, mais ca devrait fonctionner comme �a...

    A noter qu'avec un TQuery, lorsque tu fais un SELECT tu ne dois pas utiliser ExecSQL mais Open (ou Active=true).

  3. #3
    Membre �clair� Avatar de SmileSoft
    Inscrit en
    Mars 2008
    Messages
    436
    D�tails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 436
    Par d�faut
    merci sat83 pour la solution et les pr�cisions, j'ai une erreur: SQLRequeteID non d�fini, pourtant je l'ai bien renseign� dans la propri�t� Name du composant TQury

  4. #4
    Membre Expert
    Avatar de sat83
    Homme Profil pro
    D�veloppeur informatique
    Inscrit en
    Mars 2004
    Messages
    1 040
    D�tails du profil
    Informations personnelles :
    Sexe : Homme
    �ge : 41
    Localisation : France, Haut Rhin (Alsace)

    Informations professionnelles :
    Activit� : D�veloppeur informatique

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 040
    Par d�faut
    C'est que ta fonction n'est pas d�clar� dans la m�me classe que ton composant TQuery.
    Il faut ajouter la d�claration de la fonction dans ton *.h, et indiquer dans ton *.cpp que la fonction appartient � la classe :

    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    //Dans la partie private de ton *.h
    int NouvelID(AnsiString Table, AnsiString Clef) ;
    En supposant que ta classe s'appelle TForm1:
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    //Dans ton cpp
    int TForm1::NouvelID(AnsiString Table, AnsiString Clef) 
    {
    //
    }

    Ou sinon, autre solution moins "propre" :
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    int NouvelID(AnsiString Table, AnsiString Clef)
    {
        Form1->SQLRequeteID->Close(); // ou SQLRequeteID->Active = false;
        Form1->SQLRequeteID->SQL->Clear(); 
        Form1->SQLRequeteID->SQL->Add("select max(" + Clef + ") as MAX_VALUE from " + Table );
        Form1->SQLRequeteID->Open(); // ou SQLRequeteID->Active = true;
        int result = Form1->SQLRequeteID->FieldByName( "MAX_VALUE")->AsInteger + 1;
        Form1->SQLRequeteID->Close(); // ou SQLRequeteID->Active = false;
        return( result ) ;
    }

  5. #5
    Membre �clair� Avatar de SmileSoft
    Inscrit en
    Mars 2008
    Messages
    436
    D�tails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 436
    Par d�faut
    Merci beaucoup sat83 c'est bien r�solu

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

Discussions similaires

  1. Traduire ce bout de code
    Par hdgetnet dans le forum D�buter
    R�ponses: 2
    Dernier message: 25/05/2010, 17h08
  2. un petit bout de code delphi
    Par info007 dans le forum D�buter
    R�ponses: 1
    Dernier message: 23/06/2009, 16h31
  3. Traduire un bout de code de c++ vers delphi
    Par pointer dans le forum Langage
    R�ponses: 7
    Dernier message: 07/02/2009, 09h55
  4. [SQL-Server] traduire un bout de code pour oracle en bout de code pour SQL SERVER
    Par teen6517 dans le forum PHP & Base de donn�es
    R�ponses: 6
    Dernier message: 05/06/2007, 09h47
  5. R�ponses: 23
    Dernier message: 26/04/2006, 19h58

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