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

Access Discussion :

Optimisation du code VBA d'une base de données : Recordsets


Sujet :

Access

  1. #1
    Membre averti Avatar de snoopy69
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    737
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2004
    Messages : 737
    Points : 395
    Points
    395
    Par défaut Optimisation du code VBA d'une base de données : Recordsets
    Bonjour à tous ...

    Je suis en train de modifier un peu mes modules VBA de telle façon que j'aimerais OPTIMISER ma base car pour l'instant elle fonctionne en locale mais elle sera bientôt mise en réseau.

    J'ai une question concernant les : RECORDSETS

    Est-il plus judicieux de faire cela :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
       If rst_Ordinateur.RecordCount > 0 Then
     
            ... ... ...
     
       End If
    ou cela :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
       If rst_Ordinateur.EOF = false Then
     
            ... ... ...
     
       End If
    En fait si une personne qui ne s'y connait pas très bien en VBA va remprendre mon code je pense que c'est mieux d'utiliser un RECORDCOUNT que la 2ème solution ... mais ici ce n'est pas le problème ... qu'est-ce que utilise le moins de ressources entre ces 2 propositions .... ???

    Si vous avez une idée, elle sera la bienvenue. ...

    Merci de votre aide ... et de vos conseils ...
    ... Je me méfie de l'irrespect mais je revendique le droit à la frénésie ...

  2. #2
    Membre du Club

    Inscrit en
    Juin 2002
    Messages
    44
    Détails du profil
    Informations personnelles :
    Âge : 45

    Informations forums :
    Inscription : Juin 2002
    Messages : 44
    Points : 54
    Points
    54
    Par défaut
    Salut ,

    Ni l'un ni l'autre ( désolé )

    En Dao le RecordCount est remplit arès avoir fait un "MoveLast"

    Le mieux pour tester si ton Recordset est Vide est :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    if not(rst_Ordinateur.Bof) then
    Par défault lorsque tu ouvres un Recordset s'il y a des enregistrements, le curseur est sur le premier enregistrement, sinon il est juste avant c'est à dire sur le Begin Of File (BOF)


    A+

  3. #3
    Membre averti Avatar de snoopy69
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    737
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2004
    Messages : 737
    Points : 395
    Points
    395
    Par défaut
    En réponse à STEF_1 qui dit :

    Ni l'un ni l'autre ( désolé )
    Bon ben ...

    lol ...

    Je vais modifier mon code d'après ce que tu m'as dit donc :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     if not(rst_Ordinateur.Bof) then
    je crois qu c'est le mieux ...

    Merci de ton aide en tout cas ...

    Bonne journée ...
    ... Je me méfie de l'irrespect mais je revendique le droit à la frénésie ...

  4. #4
    Expert confirmé

    Homme Profil pro
    consultant développeur
    Inscrit en
    Mai 2005
    Messages
    2 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : consultant développeur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2005
    Messages : 2 878
    Points : 4 754
    Points
    4 754
    Par défaut
    Citation Envoyé par STEF_1
    Salut ,

    Ni l'un ni l'autre ( désolé )

    En Dao le RecordCount est rempli arès avoir fait un "MoveLast"
    Bonjour,
    Est-ce vraiment nécessaire ? j'ai plusieurs applis dans lesquelles j'utilise nombre de recordcount sans movelast et l'appel à Recordcount est a priori très fiable.
    "Always look at the bright side of life." Monty Python.

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    81
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 81
    Points : 88
    Points
    88
    Par défaut
    ....

  6. #6
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    81
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 81
    Points : 88
    Points
    88
    Par défaut
    Tu as aussi la possibilité de faire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    While not rst_Ordinateur.eof
         'Ton traitement
    Wend

  7. #7
    Membre habitué
    Inscrit en
    Juillet 2002
    Messages
    150
    Détails du profil
    Informations forums :
    Inscription : Juillet 2002
    Messages : 150
    Points : 169
    Points
    169
    Par défaut
    Salut,

    Le recordcount fonctionne correctement sans movelast si le recordset est de type Table, si c'est une requête il faut commencer par le parcourir en entier pour que le recordcount soit bon (enfin il me semble à confirmer, je dis ça de tête )

    Je pense qu'il faut distinguer deux choses, la logique du code d'une part et sa performance d'autre part.

    Pour estimer la performance rien ne vaut des tests avec les conditions de production (réseau, volume de donnée) et le chronomètre (cf. FAQ http://access.developpez.com/faq/?page=TAProg#TpsExe)

  8. #8
    Membre averti Avatar de snoopy69
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    737
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2004
    Messages : 737
    Points : 395
    Points
    395
    Par défaut
    Merci Nohant ... ...

    Je vais essayer ce code qui provient de la FAQ ... ...



    Encore une petite question bête ...

    Si dans un code vba qui compte environ 300 lignes pour arrondir il y a beacoup de ligne vide pour par exemple structuré le code, est-ce que la vitesse d'exécution peut être ralentie ???
    ... Je me méfie de l'irrespect mais je revendique le droit à la frénésie ...

  9. #9
    Expert éminent
    Avatar de cafeine
    Inscrit en
    Juin 2002
    Messages
    3 904
    Détails du profil
    Informations forums :
    Inscription : Juin 2002
    Messages : 3 904
    Points : 6 781
    Points
    6 781
    Par défaut
    Citation Envoyé par snoopy69
    Merci Nohant ... ...

    Je vais essayer ce code qui provient de la FAQ ... ...



    Encore une petite question bête ...

    Si dans un code vba qui compte environ 300 lignes pour arrondir il y a beacoup de ligne vide pour par exemple structuré le code, est-ce que la vitesse d'exécution peut être ralentie ???
    Je ne crois pas que le code compilé stocke les lignes vides ... enfin j'espère
    Ne mettez pas "Problème" dans vos titres, par définition derrière toute question se cache un problème
    12 tutoriels Access



  10. #10
    Membre averti Avatar de snoopy69
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    737
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2004
    Messages : 737
    Points : 395
    Points
    395
    Par défaut
    Salut cafeine ...

    Je ne crois pas que le code compilé stocke les lignes vides ... enfin j'espère
    Ouais je suis d'accord avec toi mais Access nous réserve tellement de surprise que l'on ne sait jamais à quoi s'attendre ... n'est-ce pas ???

    Ok ben merci à tout le monde pour votre aide ... ...

    et si vous avez encore des informations qui pourrait m'aider à optimiser mon code ben elles seront les bienvenues ... ...

    Merci à tous ...
    ... Je me méfie de l'irrespect mais je revendique le droit à la frénésie ...

  11. #11
    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 : 40
    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
    Pour répondre à la question

    Le .EOF est trés bien... Quand au .RecordCount il fonctionne aussi sans movelast pour ce cas... Puisque si le recordset est plein, la propriété recordcount vaut le nombre d'enregistrement dans le cas d'un recordset de type table ou 1 dans les autres cas.

    Perso, j'utilise le .EOF qui comme bof retourne directement un boolen evalué dans la condition IF.

  12. #12
    Membre habitué
    Inscrit en
    Juillet 2002
    Messages
    150
    Détails du profil
    Informations forums :
    Inscription : Juillet 2002
    Messages : 150
    Points : 169
    Points
    169
    Par défaut
    Citation Envoyé par snoopy69
    Si dans un code vba qui compte environ 300 lignes pour arrondir il y a beacoup de ligne vide pour par exemple structuré le code, est-ce que la vitesse d'exécution peut être ralentie ???
    heureusement que non
    idem pour les lignes de commentaire

    tous ce qui est mise en page et commentaire c'est pour nous, pas pour la machine

    au passage ce n'est pas directement lié, mais qq'1 connaître un utilitaire qui supprimerai automatiquement tous les commentaires et les retrait des modules VBA ?

  13. #13
    Expert éminent
    Avatar de cafeine
    Inscrit en
    Juin 2002
    Messages
    3 904
    Détails du profil
    Informations forums :
    Inscription : Juin 2002
    Messages : 3 904
    Points : 6 781
    Points
    6 781
    Par défaut
    Hello,

    As-tu testé MZTools ?
    Ne mettez pas "Problème" dans vos titres, par définition derrière toute question se cache un problème
    12 tutoriels Access



  14. #14
    Membre habitué
    Inscrit en
    Juillet 2002
    Messages
    150
    Détails du profil
    Informations forums :
    Inscription : Juillet 2002
    Messages : 150
    Points : 169
    Points
    169
    Par défaut
    Citation Envoyé par cafeine
    Hello,

    As-tu testé MZTools ?
    Salut,

    c'est pour moi ? la réponse est oui mais j'ai pas trouvé d'option pour supprimer les commentaires et les retraits dans le code
    Je sais c'est un peu spécial comme demande mais ça peut servir à l'occasion quand on tombe sur des goujats ...

Discussions similaires

  1. [Toutes versions] Extraire le code vba d'une base Access
    Par zoom61 dans le forum Contribuez
    Réponses: 3
    Dernier message: 08/11/2019, 08h41
  2. Le code de connexion à une base de données
    Par thouraya24 dans le forum Servlets/JSP
    Réponses: 1
    Dernier message: 17/06/2010, 09h46
  3. recherche en VBA dans une base de donnée excel
    Par INCO13 dans le forum Macros et VBA Excel
    Réponses: 13
    Dernier message: 24/06/2008, 13h58
  4. [MySQL] Récupération de code php dans une base de données
    Par kitana dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 21/03/2006, 00h25
  5. [Conception] Code php dans une base de donnée
    Par krfa1 dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 13/09/2005, 10h58

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