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

Requêtes et SQL. Discussion :

Resultat requete SQL dans MsgBox


Sujet :

Requêtes et SQL.

  1. #1
    Membre du Club Avatar de PhRey
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    197
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 197
    Points : 67
    Points
    67
    Par défaut Resultat requete SQL dans MsgBox
    Bonjour,
    j'aimerai pouvoir recuprer le nb d'enregistrements traités par ma requete SQL, dans une MsgBox.

    Voici mon code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Dim stDocName1 As String
    stDocName1 = "Traitement_Dossiers"
    DoCmd.OpenQuery stDocName1, acNormal, acEdit
    MsgBox "Vous avez traité " X "dossiers"
    Ma requete "Traitement_Dossiers" n'est donc pas directement executée via VBA. Mon code y fait appel via la variable stDocName1.
    Je souhaiterais recuperer le nb de lignes traitées, dans ma MsgBox.

    Auriez vous une indication sur la méthode a employer svp ?
    Merci par avance !

  2. #2
    Expert éminent sénior

    Avatar de Tofalu
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Octobre 2004
    Messages
    9 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Octobre 2004
    Messages : 9 501
    Points : 32 311
    Points
    32 311
    Par défaut
    C'est une requête sélection, elle ne traite rien

    Au pire essaye :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    MsgBox "Vous avez traité " & DCount(StDocName1,"UnChampDeLaRequete") & "dossiers"

  3. #3
    Rédacteur/Modérateur

    Avatar de Heureux-oli
    Homme Profil pro
    Contrôleur d'industrie
    Inscrit en
    Février 2006
    Messages
    21 086
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : Belgique

    Informations professionnelles :
    Activité : Contrôleur d'industrie
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 21 086
    Points : 42 925
    Points
    42 925
    Par défaut
    Ton c'est quoi.

    Je me doute que c'est le nombre de fichier, mais d'où viendrait sa valeur ?

    Tu dois lui attribuer une valeur pour qu'il l'affiche.

  4. #4
    Membre du Club Avatar de PhRey
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    197
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 197
    Points : 67
    Points
    67
    Par défaut
    Mon "X" est bien sur le nb de dossiers (ou de lignes) traités par ma requete.
    Mais je ne peux pas vraiment me servir de la variable dans la MsgBox car la variable ramene le nom de la requete, et non son contenu...

    Sinon d'une maniere generale, savez vous quel est le moyen de compter le nb de lignes traitées par une requete SQl svp ? (en vba)

    (Je pourrais peut etre executer mes requetes en VBA et compter les lignes traitées ensuite... )

    Merci pour votre aide en tout cas !

  5. #5
    Expert éminent sénior

    Avatar de Tofalu
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Octobre 2004
    Messages
    9 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Octobre 2004
    Messages : 9 501
    Points : 32 311
    Points
    32 311
    Par défaut
    Ok, donc si c'est une requête Action, openquery ne sert à rien ici.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Dim stDocName1 As String
    stDocName1 = "Traitement_Dossiers"
    CurrentDb.execute stDocName1
    MsgBox "Vous avez traité " & currentdb.RecordsAffected & "dossiers"

  6. #6
    Membre du Club Avatar de PhRey
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    197
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 197
    Points : 67
    Points
    67
    Par défaut
    Merci tofalu, mais ca ne me renvoit qu'un beau "0"

    Extrait de l'aide vba :
    Si vous utilisez la méthode Execute pour exécuter une requête Action depuis un objet QueryDef, la propriété RecordsAffected contient le nombre d'enregistrements supprimés, mis à jour ou insérés.

    Si vous utilisez la propriété RecordsAffected dans un espace de travail ODBCDirect, elle ne renverra pas de valeur utilisable à partir d'une requête Action SQL DROP TABLE.
    J'ai l'impression que ma requete n'est pas prise en compte par RecordsAffected ...

  7. #7
    Membre du Club Avatar de PhRey
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    197
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 197
    Points : 67
    Points
    67
    Par défaut
    Oups pardon je n'avais pas tout lu !
    Je reecrit mon code et je reessaye !!! desolé !

  8. #8
    Membre du Club Avatar de PhRey
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    197
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 197
    Points : 67
    Points
    67
    Par défaut
    Bon ju'ai remplacé exactement mon code par le tient, et bizarrement je reste tjrs avec la valeur "0" pour mon currentdb.RecordsAffected... Etrange d'autant que ma requete agit bien sur mes données....

  9. #9
    Expert éminent sénior

    Avatar de Tofalu
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Octobre 2004
    Messages
    9 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Octobre 2004
    Messages : 9 501
    Points : 32 311
    Points
    32 311
    Par défaut
    Et ainsi :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Dim stDocName1 As String
    Dim Db As Object
    Set Db = CurrentDb
    stDocName1 = "Traitement_Dossiers"
    Db.Execute stDocName1
    MsgBox "Vous avez traité " & Db.RecordsAffected & "dossiers"

  10. #10
    Membre du Club Avatar de PhRey
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    197
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 197
    Points : 67
    Points
    67
    Par défaut
    NICKEL !
    T'es un chef !
    Un gros merci pour ta precieuse aide (comme souvent dailleurs !!!!!)

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

Discussions similaires

  1. Réponses: 13
    Dernier message: 23/09/2011, 19h24
  2. [MySQL] affichage resultat requete sql dans tableau
    Par fasyr dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 09/04/2009, 12h18
  3. Resultat requete SQL dans SousFormulaire
    Par nabalilu dans le forum VBA Access
    Réponses: 6
    Dernier message: 03/06/2008, 17h21
  4. Réponses: 1
    Dernier message: 25/10/2005, 13h18
  5. resultat requete SQL d'un select dans variable vb
    Par seb_06 dans le forum Requêtes et SQL.
    Réponses: 12
    Dernier message: 11/10/2004, 17h29

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