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 :

firebird: ORDER BY comme paramètre


Sujet :

Bases de données Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre très actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2019
    Messages
    182
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aveyron (Midi Pyrénées)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2019
    Messages : 182
    Par défaut firebird: ORDER BY comme paramètre
    salut comment mettre ORDER BY comme paramètre
    SGBD: Firebird 2.5
    voir l'exemple suivant:

    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
     
    var variable:string;
    begin
     
    if ComboBox1.ItemIndex=0 then Variable:='Nom_Client'
    else if ComboBox1.ItemIndex=1 then Variable:='Prenom_Client';
     
    with FDQuery1 do
    begin
       Close;
       SQL.Clear;
       SQL.Add(' SELECT * FROM clients');
       SQL.Add(' ORDER BY :trier');
       ParamByName('trier').value:=Variable;
       open;
    end;
     
    end;

  2. #2
    Expert éminent
    Avatar de Paul TOTH
    Homme Profil pro
    Freelance
    Inscrit en
    Novembre 2002
    Messages
    8 964
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Novembre 2002
    Messages : 8 964
    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
    17
     
    var variable:string;
    begin
     
    if ComboBox1.ItemIndex=0 then Variable:='Nom_Client'
    else if ComboBox1.ItemIndex=1 then Variable:='Prenom_Client';
     
    with FDQuery1 do
    begin
       Close;
       SQL.Clear;
       SQL.Add(' SELECT * FROM clients');
       SQL.Add(' ORDER BY ' + Variable);
       open;
    end;
     
    end;
    Developpez.com: Mes articles, forum FlashPascal
    Entreprise: Execute SARL
    Le Store Excute Store

  3. #3
    Membre très actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2019
    Messages
    182
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aveyron (Midi Pyrénées)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2019
    Messages : 182
    Par défaut
    meeeci

  4. #4
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 654
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 654
    Billets dans le blog
    65
    Par défaut
    Bonjour,

    Il y a encore une autre manière que je trouve encore plus élégante, Firedac propose non seulement les paramètres mais aussi les macros.
    Les macros, il y en a de deux types :
    les prédéfinies qui dans ce cas ne nous intéressent pas
    mais aussi, celles qui nous intéressent et qui ressemblent beaucoup à des paramètres, notées par un & ou un !

    Exemple : SELECT * FROM clients &ordre
    On utilise alors FDQuery.Macrobyname('ordre').asRaw pour renseigner la valeur

    Exemple : FDQuery.Macrobyname('ordre').asRaw:=Format('ORDER BY %s',[variable])Note : pour ne pas indiquer d'ordre FDQuery.Macrobyname('ordre').clearMais il y a plus subtil, macrobyname peut aussi être affecté par asIdentifier
    modifions légèrement la requête SELECT * FROM clients ORDER BY &ordre (donc il doit toujours y avoir une colonne)
    on pourrait écrire FDQuery.Macrobyname('ordre').asRaw:=variablemais FDQuery.Macrobyname('ordre').asIdentifier:=variable ajouteras, en théorie, un contrôle d'existence de la colonne
    Notes :
    • J'utilise plutôt asIndentifier pour des noms de tables;
    • Je pense que asIndentifier est mieux (mais pas toujours possible à utiliser) pour parer à l'injection de SQL.



    Attention, on peut aussi mettre asString mais dans ce cas des apostrophes seront ajoutées, ce que dans le cas qui nous intéresse n'est pas une bonne chose, on ne veut pas que la requête, après pré-process devienne SELECT * FROM clients ORDER BY 'Nom_Client' => erreur SQL

    Il y a encore plus de subtilités que je n'ai pas testées comme {id } ni, a vrai dire, la plupart des macros prédéfinies n'en ayant jamais eu l'utilité
    la bible de Cary Jensen, Delphi in Depth : Firedac y consacre un chapitre entier (le 14)


    [EDIT ADDENDA]
    je trouve ce code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    if ComboBox1.ItemIndex=0 then Variable:='Nom_Client'
    else if ComboBox1.ItemIndex=1 then Variable:='Prenom_Client';
    très moyen
    soit il n'y a que deux possibilités auquel cas
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    if ComboBox1.ItemIndex=0 then Variable:='Nom_Client'
    else Variable:='Prenom_Client';
    un Case ne serait pas mal non plus, ainsi que plus "évolutif"

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    with FDQuery do 
    begin
     Close;
     Case ComboBox1.ItemIndex of
        0 : Macrobyname('ordre').asRaw:='Nom_Client';
        1 : Macrobyname('ordre').asRaw:='Prenom_Client';
        else Macrobyname('ordre').Clear;
      end; 
     Open;
    end;

  5. #5
    Expert éminent
    Avatar de Paul TOTH
    Homme Profil pro
    Freelance
    Inscrit en
    Novembre 2002
    Messages
    8 964
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Novembre 2002
    Messages : 8 964
    Par défaut
    voilà qui justifie le temps que je passe sur les forums

    je n'avais pas vu les Macros

    d'autres exemples ici
    http://docwiki.embarcadero.com/RADSt...ndes_(FireDAC)
    Developpez.com: Mes articles, forum FlashPascal
    Entreprise: Execute SARL
    Le Store Excute Store

  6. #6
    Membre très actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2019
    Messages
    182
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aveyron (Midi Pyrénées)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2019
    Messages : 182
    Par défaut
    merci

  7. #7
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 654
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 654
    Billets dans le blog
    65
    Par défaut
    Citation Envoyé par Paul TOTH Voir le message
    voilà qui justifie le temps que je passe sur les forums
    J'en écrirais autant sur tes interventions souvent inspirées

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

Discussions similaires

  1. [VBA-A]procédure avec comme paramètre une propriété
    Par eultartuffe dans le forum VBA Access
    Réponses: 2
    Dernier message: 24/04/2006, 13h49
  2. liste énumérée de const. perso comme paramètre de fonction
    Par batou22003 dans le forum VB 6 et antérieur
    Réponses: 8
    Dernier message: 13/12/2005, 20h37
  3. Réponses: 6
    Dernier message: 23/05/2005, 10h47
  4. Debutant[Table comme paramètre]
    Par lenouvo dans le forum Langage SQL
    Réponses: 2
    Dernier message: 12/05/2005, 09h04
  5. Un fichier .bmp comme paramètre d'une Procédure stockée
    Par FONKOU dans le forum Bases de données
    Réponses: 2
    Dernier message: 28/10/2004, 17h56

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