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

VBA Access Discussion :

Impossible de supprimer une table [AC-2007]


Sujet :

VBA Access

  1. #21
    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
    Bonjour,

    Apparemment c'est bien le formulaire FrmAideMajMensuelle (dont la source est TMP_MAJMensuelle)
    qui verrouille la table TMP_MAJMensuelle.
    Ce simple test reproduit le problème.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Private Sub CmdTest_Click()
    DoCmd.Close acForm, "FrmAideMajMensuelle"
    CurrentDb.Execute "DROP TABLE TMP_MAJMensuelle"
    End Sub
    Erreur 3211 : Le moteur de base de données n'a pas pu verrouiller la table 'TMP_MAJMensuelle' car elle est déjà utilisée par une autre personne ou un autre processus.

    A mon avis, la fermeture du formulaire ne peut avoir lieu qu'à la fin de l'événement "sur clic".
    C'est à dire après être sortie de la procédure événementielle.
    Or, comme l'instruction pour supprimer la table est dans cet événement, ça ne marchera jamais.
    L'idée de Keita, de détacher le formulaire de sa source me paraît bonne.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Private Sub CmdTest_Click()
    ' ... traitements ...
     
    ' On n'a plus besoin que FrmAideMajMensuelle soit lié à TMP_MAJMensuelle
    Me.RecordSource = ""
    ' On supprime la table et on ferme le formulaire
    CurrentDb.Execute "DROP TABLE TMP_MAJMensuelle"
    DoCmd.Close acForm, "FrmAideMajMensuelle"
    End Sub
    Dans ma base de test, ça fonctionne.

    A+

  2. #22
    Membre éclairé Avatar de dumas.blr
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juin 2010
    Messages
    598
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Conseil

    Informations forums :
    Inscription : Juin 2010
    Messages : 598
    Points : 879
    Points
    879
    Par défaut
    Bonjour à tous,

    N'ayant pas eu d'avis de post par mail, je n'avais pas vu que vous aviez investigué la-dessus.
    Je suis arrivé à la même conclusion que vous.

    Je m'en suis donc tiré en vidant la table à la fin du traitement
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    delete * from TMP_MAJMensuelle
    et je teste si ma table est vide.
    Je la droppe alors.

    Encore merci pour votre aide

    Jean-Yves

+ Répondre à la discussion
Cette discussion est résolue.
Page 2 sur 2 PremièrePremière 12

Discussions similaires

  1. [AC-2010] Impossible de supprimer une table, un formulaire ou une requête
    Par leonnikita dans le forum Access
    Réponses: 4
    Dernier message: 25/03/2014, 18h39
  2. Réponses: 2
    Dernier message: 16/01/2008, 19h13
  3. [ASE] Impossible de supprimer une table de type tempdb..matable
    Par Malau dans le forum Adaptive Server Enterprise
    Réponses: 4
    Dernier message: 21/11/2007, 11h13
  4. ASE 12.5.3 : impossible de supprimer une table
    Par Commandant dans le forum Sybase
    Réponses: 2
    Dernier message: 07/08/2007, 10h26
  5. Impossible de supprimer une table temporaire
    Par benjisan dans le forum Access
    Réponses: 2
    Dernier message: 27/06/2007, 09h43

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