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 :

Conversion dela variable CString au TCHAR[10]


Sujet :

MFC

  1. #1
    Membre averti
    Inscrit en
    Avril 2003
    Messages
    37
    Détails du profil
    Informations forums :
    Inscription : Avril 2003
    Messages : 37
    Par défaut Conversion dela variable CString au TCHAR[10]
    J'ai une structure que voici :
    class CdboarticleAccessor
    {
    public:
    TCHAR m_codemag[11];
    TCHAR m_codeart[11];
    DB_NUMERIC m_prixunitaire;
    TCHAR m_libelle[31];
    TCHAR m_maga[10];


    BEGIN_COLUMN_MAP(CdboarticleAccessor)
    COLUMN_ENTRY(1, m_codemag)
    COLUMN_ENTRY(2, m_codeart)
    COLUMN_ENTRY(3, m_maga)
    COLUMN_ENTRY(4, m_libelle)
    END_COLUMN_MAP()
    BEGIN_PARAM_MAP(CdboarticleAccessor)
    COLUMN_ENTRY(1, m_maga)
    END_PARAM_MAP()

    j'ai aussi un champ de mon formulaire qui est m_maga1.

    A partir de ce champ du formulaire, je voudrai affecter sa valeur dans table.m_maga qui est un parametre afin d'exécuter ma requete parametré:
    table.m_maga = m_maga1;
    hr = table.Open(session, "SELECT * FROM dbo.article where dbo.article.codemag = ?", &propset);

    A la compilation j'ai toujours une erreur de conversion à l'affectation :
    table.m_maga = m_maga1;
    comment faire SVP

    Urgent

  2. #2
    Rédacteur
    Avatar de farscape
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2003
    Messages
    9 055
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

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

    Informations forums :
    Inscription : Novembre 2003
    Messages : 9 055
    Par défaut
    salut d'apres ton code :
    tu ne peux affecteur un tableau de char a un autre tableau de char par l'operateur '= '
    il faut utiliser memmove si les 2 chaines sont de longeurs identiques ou strcpy si les chaines finissent par un null terminator.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    memmove (table.m_maga ,m_maga1,sizeof(table.m_maga ));
    // ou si avec null terminator.
    strcpy(table.m_maga ,m_maga1);

  3. #3
    Invité de passage
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    1
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 1
    Par défaut autre methode
    je ne connais pa le memmove mais si tu veux ya d methode stylé pr placer une cstring dans un buffer;
    vas voir chez msdn mais je croi ke ca ressemble a
    ta_string.GetBuffer(ton_buffer,...)
    bon le truc c ke je me rappelle plus la comme ca de ce ki a la place d ... dsl mais tu devrais ten sortir
    le truc c kapré avoir utilisé un getbuffer fo tjr fer un releasebuffer tjr hez msdn je crois kon te lexplik oci bref regarde les methodes d cstring
    ++

Discussions similaires

  1. Conversion variable string en TCHAR dans dll
    Par Pierre95 dans le forum Débuter
    Réponses: 6
    Dernier message: 10/07/2013, 12h36
  2. conversion variant en CString
    Par ep31 dans le forum MFC
    Réponses: 3
    Dernier message: 22/11/2005, 13h32
  3. [VCembedded]Conversion CTime en CString
    Par Bason_sensei dans le forum MFC
    Réponses: 8
    Dernier message: 13/10/2005, 14h39
  4. "conversion" _variant_t en CString
    Par kam dans le forum MFC
    Réponses: 4
    Dernier message: 09/03/2005, 17h41
  5. Transact Sql : Conversion de variable
    Par lord_paco dans le forum Langage SQL
    Réponses: 2
    Dernier message: 13/08/2003, 13h25

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