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 :

execution de 2 commandes sql simulanément


Sujet :

MFC

  1. #1
    Membre averti
    Inscrit en
    Mai 2005
    Messages
    12
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 12
    Par défaut execution de 2 commandes sql simulanément
    salut à tous, (APIwin32 visualc++)
    voila mon problème, comme on peut le voir ci dessous, je récupère des paramètres que j'ai au préalable rentré dans des EditBox pour les enregistrer dans ma table Cycles, cependant j'aimerais au même moment créé une nouvelle colonne dans une autre table (cf. en rouge)
    le problème étant que si je met cette commande à la suite de l'autre, seule celle ci est réalisée (et vis versa si je la place avant).
    Merci rom


    case IDC_BTNVALIDE:

    ///////////////////////////////////////////////////////////////////////////////////////////

    // On verifie qu'il y a au moins un cycle

    GetWindowText(GetDlgItem(hwndDlg, IDC_EDTCYCLE), szBuffer, TAILLE_BUFFER);

    if(lstrcmp(szBuffer, "")==0)

    {

    MessageBox(hwndDlg, "Il faut saisir au moins un Cycle.", "Erreur Saisie", MB_OK);

    SetFocus(GetDlgItem(hwndDlg, IDC_EDTCYCLE));

    break;

    }

    ///////////////////////////////////////////////////////////////////////////////////////////

    // On recupere les données

    CHAR szCycle[TAILLE_BUFFER], szType[TAILLE_BUFFER];

    lstrcpy(szCycle, szBuffer);

    GetWindowText(GetDlgItem(hwndDlg, IDC_EDTTYPE), szType, TAILLE_BUFFER);

    wsprintf(szBuffer, "INSERT INTO Cycles(Cycle, Type) VALUES ('%s', '%s')", szCycle, szType);

    wsprintf(szBuffer, "ALTER TABLE RecupParam ADD %s CHAR(10)",szCycle);



    ///////////////////////////////////////////////////////////////////////////////////////////

    // ouveture du recordset

    try

    {

    ///////////////////////////////////////////////////////////////////////////////////////////

    // fermeture du recordset s'il est ouvert

    if(pRs->State != adStateClosed)

    pRs->Close();

    ///////////////////////////////////////////////////////////////////////////////////////////

    // On Execute la requete

    pRs->Open(szBuffer, _variant_t((IDispatch *) pConn, true), adOpenDynamic, adLockReadOnly, adCmdText);

    }

    catch(_com_error &e)

    {

    MessageBox(hwndDlg, e.Description(), "Erreur ExecuteRequete.", MB_ICONEXCLAMATION);

    }

    ///////////////////////////////////////////////////////////////////////////////////////////

    // On remplit la liste Cycle

    wsprintf(szBuffer, "SELECT * FROM Cycles ORDER BY Cycle, Type");

    RempliListeCycle(GetParent(hwndDlg), szBuffer);

    SetWindowText(GetDlgItem(GetParent(hwndDlg), IDC_LBLCYCLE), szCycle);

    SetWindowText(GetDlgItem(GetParent(hwndDlg), IDC_LBLTYPE), szType);

    ///////////////////////////////////////////////////////////////////////////////////////////

    // On relance la boite de dialogue

    SendMessage(hwndDlg, WM_NEXTDLGCTL, 0, 0);

    SetWindowText(GetDlgItem(hwndDlg, IDC_EDTTYPE), "");

    SetWindowText(GetDlgItem(hwndDlg, IDC_EDTCYCLE), "");

    break;[/size]

  2. #2
    Membre chevronné
    Avatar de matazz
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    471
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 471
    Par défaut
    ben je te dirai a première vue que c'est normal, car tu as un recordset par requête, moi je ferai :

    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
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
     
    wsprintf(szBuffer, "INSERT INTO Cycles(Cycle, Type) VALUES ('%s', '%s')", szCycle, szType); 
     
     
    // ouveture du recordset 
     
    try 
     
    { 
     
    /////////////////////////////////////////////////////////////////////////////////////////// 
     
    // fermeture du recordset s'il est ouvert 
     
    if(pRs->State != adStateClosed) 
     
    pRs->Close(); 
     
    /////////////////////////////////////////////////////////////////////////////////////////// 
     
    // On Execute la requete 
     
    pRs->Open(szBuffer, _variant_t((IDispatch *) pConn, true), adOpenDynamic, adLockReadOnly, adCmdText); 
     
    } 
     
    catch(_com_error &e) 
     
    { 
     
    MessageBox(hwndDlg, e.Description(), "Erreur ExecuteRequete.", MB_ICONEXCLAMATION); 
     
    } 
     
    //Et la deuxième.....
    wsprintf(szBuffer, "ALTER TABLE RecupParam ADD %s CHAR(10)",szCycle); 
     
    // ouveture du recordset 
     
    try 
     
    { 
     
    /////////////////////////////////////////////////////////////////////////////////////////// 
     
    // fermeture du recordset s'il est ouvert 
     
    if(pRs->State != adStateClosed) 
     
    pRs->Close(); 
     
    /////////////////////////////////////////////////////////////////////////////////////////// 
     
    // On Execute la requete 
     
    pRs->Open(szBuffer, _variant_t((IDispatch *) pConn, true), adOpenDynamic, adLockReadOnly, adCmdText); 
     
    } 
     
    catch(_com_error &e) 
     
    { 
     
    MessageBox(hwndDlg, e.Description(), "Erreur ExecuteRequete.", MB_ICONEXCLAMATION); 
     
    }

  3. #3
    Membre averti
    Inscrit en
    Mai 2005
    Messages
    12
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 12
    Par défaut
    c'est vrai c'était pourtant évident, en tout cas un grand merci, ça me bloquait énormémént depuis ce matin et maintenant ca marche!
    ciao

  4. #4
    Membre chevronné
    Avatar de matazz
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    471
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 471
    Par défaut
    de rien.

  5. #5
    Membre Expert
    Avatar de Ti-R
    Homme Profil pro
    Ingénieur R&D
    Inscrit en
    Avril 2003
    Messages
    1 683
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2003
    Messages : 1 683
    Par défaut
    Merci d'indiquer résolu en bas à gauche stp

Discussions similaires

  1. Mon script de commande sql ne s'execute pas !
    Par Battosaiii dans le forum SQL
    Réponses: 3
    Dernier message: 18/04/2011, 14h23
  2. Execution de commande SQL
    Par Anduriel dans le forum VB.NET
    Réponses: 3
    Dernier message: 23/10/2010, 16h05
  3. Réponses: 3
    Dernier message: 08/08/2006, 14h07
  4. Execution d'un script SQL
    Par Drahu dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 05/03/2004, 16h55
  5. [dBase]il y a mieux que la commande sql UPDATE ?
    Par sana72 dans le forum Autres SGBD
    Réponses: 4
    Dernier message: 12/12/2002, 11h59

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