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

IHM Discussion :

recordset et formulaire


Sujet :

IHM

  1. #1
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Juillet 2011
    Messages
    32
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vaucluse (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Juillet 2011
    Messages : 32
    Points : 22
    Points
    22
    Par défaut recordset et formulaire
    Bonjour,
    j'ai un pb de navigation dans un recordset. Ma table est composée de 6 enregistrements et quand j'ouvre mon recordset je me retrouve sur l'enregistrement N°5 de ma table. Comment je fais pour tomber sur le premier enregistrement?

    je place mon code dans le module Form Load:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Set oDb = CurrentDb
     
    Set oRst = oDb.OpenRecordset("Stage", dbOpenSnapshot)
        oRst.MoveLast  
        oRst.MoveFirst
     
        'test de la structure
        champ1 = oRst.Fields(0)
        champ2 = oRst.Fields(1)
        champ3 = oRst.Fields(2)
        champ4 = oRst.Fields(3)
    Voila je ne comprends pas ce qui se passe.....

  2. #2
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    169
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 169
    Points : 100
    Points
    100
    Par défaut
    Je pense que l'ordre par défaut est défini sur l'index courant, pas forcément comment la table "physique" est ordonnée.

  3. #3
    Invité
    Invité(e)
    Par défaut
    Bonjour
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Set oDb = CurrentDb
     
    Set oRst = oDb.OpenRecordset("Stage", dbOpenSnapshot)
     
        'test de la structure
        champ1 = oRst.Fields(0)
        champ2 = oRst.Fields(1)
        champ3 = oRst.Fields(2)
        champ4 = oRst.Fields(3)
    Et sans se déplacer, il se positionne où?

  4. #4
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Juillet 2011
    Messages
    32
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vaucluse (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Juillet 2011
    Messages : 32
    Points : 22
    Points
    22
    Par défaut
    en fait sans se déplacer il se place sur le même enregistrement le n°5.

  5. #5
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Juillet 2011
    Messages
    32
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vaucluse (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Juillet 2011
    Messages : 32
    Points : 22
    Points
    22
    Par défaut
    j'ai fait un test en changeant le type d'objet en "dbOpenDynaset" et là mon index est bien sur le premier enregistrement.
    Juste par curiosité, est-ce quelqu'un peut m'expliquer?
    merci

  6. #6
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    169
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 169
    Points : 100
    Points
    100
    Par défaut
    Citation Envoyé par alain136 Voir le message
    j'ai fait un test en changeant le type d'objet en "dbOpenDynaset" et là mon index est bien sur le premier enregistrement.
    Juste par curiosité, est-ce quelqu'un peut m'expliquer?
    merci
    Je pense que Dynaset prend en compte l'index de ta table (s'il y en a un?). Le snapshot prend l'ordre physique (ton enreg#5 doit être le plus ancien)

    Pour éviter les surprises, utilise ORDER BY...

Discussions similaires

  1. [AC-2010] Remplacer DAO par ADO pour les recordset des formulaires
    Par talere dans le forum VBA Access
    Réponses: 2
    Dernier message: 31/01/2012, 13h30
  2. [AC-2007] recordset sous-formulaire access
    Par olivier41 dans le forum VBA Access
    Réponses: 4
    Dernier message: 22/02/2011, 05h00
  3. [AC-2003] Nombre d'enregistrements du recordset du formulaire
    Par Plexi86 dans le forum IHM
    Réponses: 0
    Dernier message: 06/10/2010, 06h19
  4. Access - vba recordset sous-formulaire
    Par jedi186 dans le forum VBA Access
    Réponses: 17
    Dernier message: 01/06/2008, 13h02
  5. Réponses: 11
    Dernier message: 16/12/2005, 14h44

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