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 :

[VBA] Supprimer des lignes dans une table


Sujet :

Access

  1. #1
    Membre à l'essai
    Inscrit en
    Août 2006
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 27
    Points : 22
    Points
    22
    Par défaut [VBA] Supprimer des lignes dans une table
    Bonjour,

    Je souhaite supprimer des lignes dans une table. Elle se presente comme ceci:

    NumSociete Total_Nb Total_Montant
    31
    32
    ...
    90
    31
    32
    ...
    92

    Je voudrais supprimer les lignes a partir de la ligne ou NumSociete = 31 pour la seconde fois.
    J'ai pense a un recordet mais ma methode findfirst ne marche pas (cf ci dessous) ... Si vous avez des idees. Merci !!!!!
    Greg

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Sub test()
    Dim rst as DAO.recordet
    set rst = Currentdb.openrecorset("ClientsTable") 
    rst.movefirst
    rst.findfirst("NumSociete = 31") 
    rst.find next
    while rst.eof
    rst.delete
    End sub
    Autre idee : une requete action (delete) mais ce me parait plus complique.

  2. #2
    Membre expert
    Avatar de FreeAccess
    Homme Profil pro
    Un monde ou prendre est plus facile qu'apprendre.
    Inscrit en
    Mars 2006
    Messages
    2 745
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Un monde ou prendre est plus facile qu'apprendre.

    Informations forums :
    Inscription : Mars 2006
    Messages : 2 745
    Points : 3 834
    Points
    3 834
    Par défaut
    Bonjour,

    En fait est-ce que tu ne veux pas simplement supprimer de ta table les enregistrements en double qui s'y trouve

    Si c'est le cas, oriente toi vers une requête "Recherche doublon"........

    En espérant avoir compris ton problème.
    FreeAccess
    "Petit à petit l'araignée tisse sa toile"

  3. #3
    Membre à l'essai
    Inscrit en
    Août 2006
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 27
    Points : 22
    Points
    22
    Par défaut
    Les deux groupes de donnees ne sont pas tt a fait des doublons.
    Ce sont des infos legerement differentes. Je nai besoin que du premier bloc.
    Je vais vior du cote de la requete doublons mais je ne pense pas que cela resolve le prb.

  4. #4
    Membre éclairé Avatar de ft035580
    Profil pro
    Inscrit en
    Août 2004
    Messages
    689
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2004
    Messages : 689
    Points : 799
    Points
    799
    Par défaut
    Salut,

    comme le dit "FreeAccess" tu peux t'orienter vers une requête doublon mais je ne suis pas trop inspiré.

    Sinon,en reprenant l'idée de la FAQ:

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT ClientsTable_1.[NumSociete Total_Nb Total_Montant] INTO ClientsTable2
    FROM ClientsTable AS ClientsTable_1
    GROUP BY ClientsTable_1.[NumSociete Total_Nb Total_Montant]
    ORDER BY ClientsTable_1.[NumSociete Total_Nb Total_Montant];

    Tu crées une nouvelle table

    Bon courage.

  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
    Y a t'il un champ gérant pouvant servir de numéro de ligne ?

  6. #6
    Membre à l'essai
    Inscrit en
    Août 2006
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 27
    Points : 22
    Points
    22
    Par défaut
    Slt Tofalu,

    Le champ ID cree lors de l'import peut servir de numero de ligne.
    ID Num_Societe
    1 31
    2 32
    ... ...
    90 31
    91 33
    ... ...

    Sinon je ne suis pas contre recreer une table mais comment le code sql ci dessus parvient a reconnaitre mes deux groupes de donnees et a ne prendre que le 1er groupe dans la nvle table?

    Merci opur les explications,
    Greg

  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    41
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 41
    Points : 51
    Points
    51
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    Dim oRst as DAO.Recordset
    Dim oDb as DAO.Database
    Set oDb=currentdb
    Set oRst=oDb.OpenRecordset("select * from ClientsTable where NumSociete >=31", dbOpenDynaset)
    while not(oRst.EOF)
      oRst.Delete
      oRst.MoveNext
    wend
    oRst.close
    oDb.close
    Set oRSt=nothing
    Set oDb=nothing
    ptet un truc comme ca
    mais si tu as des enregistrement connexes, il va falloir supprimer ceux ci avant de supprimer tes sociétés
    Un chat avec des moufles n'attrape pas de souris.

Discussions similaires

  1. supprimer des lignes dans une table SAS
    Par yoyo44ima dans le forum SAS Base
    Réponses: 7
    Dernier message: 25/05/2011, 09h39
  2. Supprimer des lignes dans une table
    Par ToniConti dans le forum Pentaho
    Réponses: 5
    Dernier message: 03/08/2010, 23h09
  3. la couleur des lignes dans une table
    Par Platon93 dans le forum Access
    Réponses: 3
    Dernier message: 30/11/2006, 15h05
  4. Réponses: 14
    Dernier message: 22/09/2005, 16h49
  5. Ajout/Suppression dynamique des lignes dans une table
    Par codexomega dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 13/08/2005, 18h50

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