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

MFC Discussion :

precompile #define


Sujet :

MFC

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Décembre 2004
    Messages
    46
    Détails du profil
    Informations forums :
    Inscription : Décembre 2004
    Messages : 46
    Par défaut precompile #define
    j'ai voulu faire propre et définir mes requetes en haut du fichier ou elles se trouvent pour les retoucher plus facilement (sans avoir à les chercher partout)

    les requetes simples, y a pas de soucis, mais pour celles avec argument, ils ne me changent pas les paramètres, et je suppose que c'est lié au fait que c'est un string :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    #define _REQUETE_EP(__c__) "SELECT id_e, num_eprouv FROM eprouvette WHERE id_code_acier=__c__ ORDER BY num_eprouv ASC"
    renvoie le texte tel quel, sans changer __c__ par la valeur passée. Faut il faire quelque chose de spécial pour que ça le fasse ?

  2. #2
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 393
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 393
    Par défaut
    oui, il faut qch de spécial.

    Si __c__ est une chaîne, tu peux faire juste
    "... WHERE id_code_acier=" __c__ " ORDER BY..."

    Sinon, je ne sais pas trop... Je ne crois pas que l'opérateur de concaténation ## marche entre un nombre et une chaîne (avec un identificateur, ça marche, mais une chaîne, je ne suis pas sur)
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  3. #3
    Membre averti
    Inscrit en
    Décembre 2004
    Messages
    46
    Détails du profil
    Informations forums :
    Inscription : Décembre 2004
    Messages : 46
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    #define _REQUETE_EP(__c__) "SELECT id_e, num_eprouv FROM eprouvette WHERE id_code_acier=" + CastInt(__c__) + " ORDER BY num_eprouv ASC"
    où CastInt est une fonction prenant un int en argument et renvoyant un CString


    ça marche comme ça


    merci

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

Discussions similaires

  1. #define D3D_DEBUG_INFO
    Par moldavi dans le forum DirectX
    Réponses: 7
    Dernier message: 03/02/2005, 14h14
  2. INSO Filter : "USER-defined exception" avec ctx_do
    Par Wiztiti dans le forum Oracle
    Réponses: 2
    Dernier message: 01/06/2004, 16h14
  3. USER DEFINE FONCTION : PB éxécution requête
    Par juelo dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 26/01/2004, 11h12
  4. Define sur plusieurs lignes
    Par Gogoye dans le forum C
    Réponses: 6
    Dernier message: 06/10/2003, 11h45
  5. define avec GCC.
    Par vagabon dans le forum Autres éditeurs
    Réponses: 4
    Dernier message: 12/06/2003, 14h04

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