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 :

Compter le nombre de réponses me donne "-1"


Sujet :

Requêtes et SQL.

  1. #1
    Membre du Club
    Inscrit en
    Mars 2006
    Messages
    95
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 95
    Points : 60
    Points
    60
    Par défaut Compter le nombre de réponses me donne "-1"
    bonsoir,

    J'essai d'afficher le nombre de réponse d'un RecordSet :


    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
     
    cnn.Open
     
    saisi.Show
     
     
    requetteSQL = "SELECT idOperation " _
        & "FROM operation;"
     
    rst.Open requetteSQL, cnn
     
    nombre_de_bouttons = rst.RecordCount
     
     
    MsgBox nombre_de_bouttons, vbDefaultButton1
     
    'While Not (rst.EOF)
    '  MsgBox rst("idOperation") & "."
    '  rst.MoveNext
    'Wend
    J'obtiens "-1" comme affichage. Alors que si je commente ma ligne qui affiche mon RecordCount et qu'à la place je parcours mon RecordSet (la partie commenté), j'obtiens 4 résultats, et donc 4 popup.

    Pourquoi obtiendrai-je "-1" et non "4" ?

    Merci pour vos éclairages.

  2. #2
    Expert éminent
    Avatar de LedZeppII
    Homme Profil pro
    Maintenance données produits
    Inscrit en
    Décembre 2005
    Messages
    4 485
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Maintenance données produits
    Secteur : Distribution

    Informations forums :
    Inscription : Décembre 2005
    Messages : 4 485
    Points : 7 759
    Points
    7 759
    Par défaut
    Bonsoir,

    La méthode Open d'un recordset ADO comporte 5 arguments et tu n'en fournis que 2.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    recordset.Open Source, ActiveConnection, CursorType, LockType, Options
    Par défaut CursorType=adOpenForwardOnly et LockType=adLockReadOnly.
    Dans ce cas la propriété RecordCount n'est pas disponible avec le fournisseur de données Microsoft.Jet.OLEDB.4.0
    Essaie
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    rst.Open requetteSQL, cnn, adOpenStatic
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    rst.Open requetteSQL, cnn, adOpenKeyset
    A+

  3. #3
    Membre du Club
    Inscrit en
    Mars 2006
    Messages
    95
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 95
    Points : 60
    Points
    60
    Par défaut
    J'utilise une base MySQL 5. J'ai testé les 2 options au cas ou, mais ça ne marche pas.


    Je cherchais comment faire mon select count(*) tous simplement parce que je ne trouvais pas comment récuperer mon résultat. Je viens de voir qu'on pouvait afficher un rst(0) pour afficher le résultat au lieu de rst("monchamp").

    Merci beaucoup pour ton aide !

  4. #4
    Expert éminent
    Avatar de LedZeppII
    Homme Profil pro
    Maintenance données produits
    Inscrit en
    Décembre 2005
    Messages
    4 485
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Maintenance données produits
    Secteur : Distribution

    Informations forums :
    Inscription : Décembre 2005
    Messages : 4 485
    Points : 7 759
    Points
    7 759
    Par défaut
    Bonsoir,

    avec MySQL et le driver ODBC je peux utiliser RecordCount à condition que le curseur soit côté client:
    Code vb : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    rst.CursorLocation = adUseClient
    rst.Open requetteSQL, cnn
    A+

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 14/01/2009, 17h14
  2. Réponses: 3
    Dernier message: 08/07/2008, 11h06
  3. [XPATH] Compter le nombre d'attributs qui ont une valeur donné
    Par doozor dans le forum XSL/XSLT/XPATH
    Réponses: 2
    Dernier message: 26/05/2008, 10h06

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