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

VBA Access Discussion :

Relancer une requête sous VB


Sujet :

VBA Access

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    17
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 17
    Points : 15
    Points
    15
    Par défaut Relancer une requête sous VB
    Bonjours,

    Je suis bloqué sur une [Procédure événementielle] que j'ai affecté à un bouton de mon formulaire. Le code ce présente ainsi :

    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
    Private Sub Ajout_NITG_Click()
    On Error GoTo Erreur
     
        Dim requete As String
        Dim VarLr As Variant
     
        For Each VarLr In NITG_NA.ItemsSelected
            requete = "INSERT INTO NITG_CC VALUES ( '" & Liste_CC.Column(0) & "','" & NITG_NA.Column(1, VarLr) & "' ) "
            CurrentDb.Execute requete
        Next VarLr
     
        CurrentDb.Execute "SELECT NITG.GFS, NITG.NITG, NITG.NITGLIB FROM NITG_CC RIGHT JOIN NITG ON NITG_CC.NITG = NITG.NITG GROUP BY NITG.GFS, NITG.NITG, NITG.NITGLIB HAVING (((Count(NITG_CC.CC))=0));" ' Ne marche pas!
     
        Liste_CC.Requery
        NITG_NA.Requery
        NITG_Affecté.Requery
     
    Sortie:
        Exit Sub
     
    Erreur:
        MsgBox Err.Description, vbCritical, "Erreur de Transfert"
        Resume Sortie
    End Sub
    Le problème que je rencontre est que j'arrive à executer la requête SQL (Le code SQL est un copier/coller du code que m'a généré ACCESS) me permettant de mettre à jours une liste.

    Le message d'erreur qui s'affiche est le suivant :

    "impossible d'éxecuter une requête de séléction."

    Merci d'avance.

    PS : Je suis un novice d'ACCESS, mais j'ai beaucoup fait de VBA sous EXCEL.

  2. #2
    Expert confirmé
    Avatar de pc75
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    3 662
    Détails du profil
    Informations personnelles :
    Âge : 69
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2004
    Messages : 3 662
    Points : 4 047
    Points
    4 047
    Par défaut
    Bonjour,

    A priori, Execute sert à exécuter une requête action (insert, delete ou update).

    Pour un select => recordset

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    17
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 17
    Points : 15
    Points
    15
    Par défaut
    Merci pour cette réponse rapide, mais comment ceci se traduirai donc en code?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    CurrentDb.Recordset "SELECT NITG.GFS, NITG.NITG, NITG.NITGLIB FROM NITG_CC RIGHT JOIN NITG ON NITG_CC.NITG = NITG.NITG GROUP BY NITG.GFS, NITG.NITG, NITG.NITGLIB HAVING (((Count(NITG_CC.CC))=0));"
     
    Recorset "SELECT NITG.GFS, NITG.NITG, NITG.NITGLIB FROM NITG_CC RIGHT JOIN NITG ON NITG_CC.NITG = NITG.NITG GROUP BY NITG.GFS, NITG.NITG, NITG.NITGLIB HAVING (((Count(NITG_CC.CC))=0));"
     
    ou
     
    CurrentDb.Execute "UPDATE NITG.GFS, NITG.NITG, NITG.NITGLIB FROM NITG_CC RIGHT JOIN NITG ON NITG_CC.NITG = NITG.NITG GROUP BY NITG.GFS, NITG.NITG, NITG.NITGLIB HAVING (((Count(NITG_CC.CC))=0));"
    Ceci n'a pas l'air de marché.

    Pour faire simple comment executer à nouveau ma requête?

  4. #4
    Membre régulier

    Inscrit en
    Août 2005
    Messages
    102
    Détails du profil
    Informations forums :
    Inscription : Août 2005
    Messages : 102
    Points : 119
    Points
    119
    Par défaut
    Ca dépend pour quoi tu veux utiliser ta requête:

    -pour lire/modifer son contenu dans VBA, utilise un recordset. Syntaxe ici :
    http://access.developpez.com/faq/?page=SQL

    -pour rafraichir ton formulaire: -pour changer ce que montre ton formulaire:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Me.RecordSource="nom ou texte de la requête"
    Me.Requery

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    17
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 17
    Points : 15
    Points
    15
    Par défaut
    Merci pour cette réponse, me semble un peu plus clair.

    Mais lorsque j'ecris :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    CurrentDb.RecordSource = "Texte de la requete"
    ça ne marche pas, dois je définir une variable ou je ne sais quoi?

    Parcontre suite à ton liens il me semblerai que

    [CODE]CurrentDb.Execute "UPDATE _"[CODE]

    me semblerai approprié à ma demande mais je ne sais pas pour autant quoi ecrire derrière UPDATE.

    EDIT : Enfait il suffit de mettre

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Me.RecordSet = "requete"
    Super merci beaucoup!!!

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

Discussions similaires

  1. comment rajouter un caractère " ' " dans une requê
    Par GDVL dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 30/07/2004, 16h58
  2. [ADRESSAGE][DEBUTANT]Accés à une machine dans un sous-réseau
    Par Milark dans le forum Développement
    Réponses: 4
    Dernier message: 26/03/2004, 09h45
  3. execution d'une macro d'access sous delphi
    Par galendor_d'ambre dans le forum Bases de données
    Réponses: 6
    Dernier message: 10/02/2004, 15h58
  4. [dbase3]Convertir une base de données sous windows
    Par nux dans le forum Autres SGBD
    Réponses: 2
    Dernier message: 04/10/2003, 14h25
  5. Une base de données sous windows ???
    Par nux dans le forum Décisions SGBD
    Réponses: 10
    Dernier message: 23/09/2003, 16h04

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