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

Contribuez Discussion :

Tri de données dans un tableau [Trucs & Astuces]


Sujet :

Contribuez

  1. #1
    Membre régulier Avatar de GESCOM2000
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    107
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 107
    Points : 79
    Points
    79
    Par défaut Tri de données dans un tableau
    je ne connait pas trop les fonction pour faire un tableau

    J'ai 2 tables TABLE1 et TABLE2 avec 1 champs C1

    j'ouvre mon recorset sur la table TABLE1 et je recupere tout les champs C1 dans un tableau et la je veux trier les valeur dans mon tableau pour les ecrire dans une autre table TABLE2

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Set dB = DBEngine(0)(0)
    Set rs = dB.OpenRecordset("SELECT blablabla...")
    rs.MoveFirst
    While Not rs.EOF
     
        If rs!C1 = DVALEUR1 Then
        ' La je fait un tableau (ne sait pas faire..)
     
    End If
        rs.MoveNext
    Wend
    Rs.close
    'puis avec les valeur de mon tableau trie je les balance dans le table2....

  2. #2
    Responsable
    Office & Excel


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 122
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur et développeur chez EXCELLEZ.net
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 122
    Points : 55 921
    Points
    55 921
    Billets dans le blog
    131
    Par défaut
    Bonjour

    Le plus simple est de trier dans ta requête

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select c1 from MaTable ORDER BY c1
    Si tu passes par le tableau pour uniquement retrier, oublies ton tableau et travailles directement avec les recordsets.

    Ok?

    Pierre Fauconnier
    "Plus les hommes seront éclairés, plus ils seront libres" (Voltaire)
    ---------------
    Mes billets de blog sur DVP
    Mes remarques et critiques sont purement techniques. Ne les prenez jamais pour des attaques personnelles...
    Pensez à utiliser les tableaux structurés. Ils vous simplifieront la vie, tant en Excel qu'en VBA ==> mon tuto
    Le VBA ne palliera jamais une mauvaise conception de classeur ou un manque de connaissances des outils natifs d'Excel...
    Ce ne sont pas des bonnes pratiques parce que ce sont les miennes, ce sont les miennes parce que ce sont des bonnes pratiques
    VBA pour Excel? Pensez D'ABORD en EXCEL avant de penser en VBA...
    ---------------

  3. #3
    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
    Le mieux, vraiment le mieux de par sa performance :

    Etape1 : Créer une requête comme indiqué avec la clause ORDER BY. Nommer cette requete par exemple R01

    Etape2 : Dans le code VBA, instancier un objet QueryDef correspond à la requête

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Dim oDb as DAO.Database
    Dim oQdf as DAO.QueryDef
    Set oDb=CurrentDb
    Set oQdf=oDb.QueryDefs("R01")
    Etape3 : Ouvrir un recordset sur l'objet QueryDef

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Dim oRst as DAO.RecordSet
    Set oRst=oQdf.OpenRecordSet
    Etape4 : Utiliser la methode GetRows pour récuperer le tableau correspondant. Cf le tutoriel http://warin.developpez.com/access/d...=partie_5#L5.5

    De cette manière tu auras la code le plus performant possible.

    Deux questions surviennent alors

    Pourquoi utiliser un objet QueryDef et non pas directement du SQL dans le VBA ?

    Tout simplement parce que les objets QueryDef profite de l'effet Rushmore, et tirent un maximum parti des champs indexés (donc gain de temps sur les tris)

    Pourquoi la méthode GetRows ?

    Parce qu'elle est faite pour cela et là encore, elle est optimisée.

  4. #4
    Membre régulier Avatar de GESCOM2000
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    107
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 107
    Points : 79
    Points
    79
    Par défaut
    Merci Tofalu,
    Bon j'ai lu et pas tout pigé le GETROWS (y as des jour comme ça...)

    Donc j'ai fait une bidouille à 2 balles (c'est lourd mais ça marche...)

    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
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    Dim dB As Database
    Dim rs As Recordset
    Dim TABLEAU(1 To 10) As Variant
    Dim COMPTE As Variant
    Dim I As Integer
    Dim II As Integer
    Dim III As Integer
     
    I = 0
    II = 0
     
    Set dB = DBEngine(0)(0)
    Set rs = dB.OpenRecordset("SELECT TABLE_1.VALEUR_1, TABLE_1.VALEUR_2 FROM TABLE_1 ORDER BY TABLE_1.VALEUR_1;")
     
    rs.MoveFirst
     
    While Not rs.EOF
        I = I + 1
     
        If rs!VALEUR_1 = ME.LST_1 Then
        II = II + 1
        TABLEAU(I) = rs!VALEUR2
        End If
     
        rs.MoveNext
    Wend
    rs.Close
     
    III = 0
    II = II + 1
    COMPTE = 0
     
    For III = II To I
    	COMPTE = COMPTE + TABLEAU(III)
    Next
     
    II = II - 1
    ME.TXT_1.Caption = Round(COMPTE / II, 2)
    J'aimerais quand même pas mourir bête, et comprendre la fonction GETROWS avec ma bidouille.....

  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 : 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
    Attends, j'ai détaillé completement la marche à suivre notamment :

    CurrentDb
    QueryDef

    Tu n'en tiens pas du tout compte. Je me demande vraiment à quoi cela serve qu'on passe notre temps à la rédaction de ressources

    Quant aux déclarations des variables et autres ... c'est le genre de code qui est immaintenable...

  6. #6
    Membre régulier Avatar de GESCOM2000
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    107
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 107
    Points : 79
    Points
    79
    Par défaut
    désoler, tu as raison j'ai pas tout lu et c'est vraiment bien expliquer dans
    Cf le tutoriel....
    Un peu fatiguer ce week-end
    Merci

  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    141
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 141
    Points : 61
    Points
    61
    Par défaut
    Moi j'ai suivi tes conseils et ca marche nickel

    merci tofalu
    en plus c'est super bien expliqué

Discussions similaires

  1. [MySQL] Stocker des données dans un tableau
    Par LadyArwen dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 02/02/2006, 10h40
  2. Réponses: 3
    Dernier message: 11/01/2006, 17h44
  3. Réponses: 3
    Dernier message: 05/12/2005, 02h30
  4. Trier les données dans 1 tableau par ordre décroissant
    Par Blunet dans le forum VB 6 et antérieur
    Réponses: 8
    Dernier message: 23/11/2005, 09h56
  5. [XML-XSLT] Données dans un tableau
    Par Hoegaarden dans le forum XSL/XSLT/XPATH
    Réponses: 5
    Dernier message: 10/12/2004, 15h51

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