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 :

Supprimer une Table si existante


Sujet :

Access

  1. #1
    Membre habitué Avatar de Orakle
    Homme Profil pro
    Responsable Informatique
    Inscrit en
    Mars 2004
    Messages
    204
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Aube (Champagne Ardenne)

    Informations professionnelles :
    Activité : Responsable Informatique
    Secteur : Transports

    Informations forums :
    Inscription : Mars 2004
    Messages : 204
    Points : 154
    Points
    154
    Par défaut Supprimer une Table si existante
    Bonjour,

    je cherche l'expression VBA qui me traduit :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Si la Table MaTable existe alors la supprimer !
    J'ai trouvé quelque chose d'à peu près similaire sur les requêtes mais ce n'est pas exactement ce que je cherche.

    Si quelqu'un pouvait m'aider

    merci

  2. #2
    Expert confirmé

    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 419
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 419
    Points : 4 297
    Points
    4 297
    Par défaut
    on error resume next
    supprimer table
    on error goto 0

  3. #3
    Membre habitué Avatar de Orakle
    Homme Profil pro
    Responsable Informatique
    Inscrit en
    Mars 2004
    Messages
    204
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Aube (Champagne Ardenne)

    Informations professionnelles :
    Activité : Responsable Informatique
    Secteur : Transports

    Informations forums :
    Inscription : Mars 2004
    Messages : 204
    Points : 154
    Points
    154
    Par défaut
    Je ne comprend pas le sens de cette réponse, tu peux m'en dire plus stp ?

  4. #4
    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 : 41
    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
    Citation Envoyé par Orakle
    Je ne comprend pas le sens de cette réponse, tu peux m'en dire plus stp ?
    Tout simplement, tu tentes de supprimer la table, et si une erreur survient tu la gère. C'est ce que fait le on error resume next

    Exemple :

    On error resume next
    CurrentDb.Execute "DROP TABLE MATABLE"

  5. #5
    Membre expérimenté
    Avatar de Mahefasoa
    Homme Profil pro
    Manager IT
    Inscrit en
    Octobre 2003
    Messages
    835
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Madagascar

    Informations professionnelles :
    Activité : Manager IT

    Informations forums :
    Inscription : Octobre 2003
    Messages : 835
    Points : 1 664
    Points
    1 664
    Par défaut
    Salut,

    Consulte dans l'aide d'Access la méthode DeleteObject de DoCmd qui (je crois) te permettras de supprimer un objet de la base de données.
    Pour vérifier l'existence d'une table dans la base, recherche dans le FAQ tu y trouveras ce dont tu as besoin.

    Bon courage

    Voici l'extrait du fichier d'aide d'Access qui t'explique l'utilisation de la méthode DeleteObject

    La méthode DeleteObject exécute l'action DeleteObject dans Visual Basic.

    expression.DeleteObject(TypeObjet, NomObjet))
    expression Requise. Expression renvoyant l'un des objets figurant dans la liste Application.

    TypeObjet AcObjectType facultatif.

    AcObjectType peut être l'une de ces constantes AcObjectType.
    acDataAccessPage
    acDefault default
    acDiagram
    acForm
    acFunction
    acMacro
    acModule
    acQuery
    acReport
    acServerView
    acStoredProcedure
    acTable

    NomObjet Variant facultatif. Expression chaîne qui est le nom valide d'un objet du type sélectionné avec l'argument typeobjet . Si vous exécutez du code Visual Basic contenant la méthode DeleteObject dans une base de données bibliothèque, Microsoft Access recherche un objet de ce nom d'abord dans la base de données bibliothèque, puis dans la base de données en cours.

    Remarques
    Pour plus d'informations sur le mode de fonctionnement de l'action et de ses arguments, reportez-vous à la rubrique Action.

    Si vous laissez les arguments typeobjet et nomobjet vierges (la constante par défaut acDefault est choisie pour typeobjet), Microsoft Access supprime l'objet sélectionné dans la fenêtre Base de données. Vous pouvez utiliser l'action SelectObject ou la méthode SelectObject en attribuant Oui (True) à l'argument In Database Window.

    Exemple
    Cet exemple supprime la table spécifiée :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DoCmd.DeleteObject acTable, "Former Employees Table"

  6. #6
    Membre habitué Avatar de Orakle
    Homme Profil pro
    Responsable Informatique
    Inscrit en
    Mars 2004
    Messages
    204
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Aube (Champagne Ardenne)

    Informations professionnelles :
    Activité : Responsable Informatique
    Secteur : Transports

    Informations forums :
    Inscription : Mars 2004
    Messages : 204
    Points : 154
    Points
    154
    Par défaut
    Bonjour,

    déjà merci à vous pour vos réponses !

    @mahefasoa, merci pour le docmd.deleteObject mais c'est déjà ce que j'utilise !

    Je me rend compte que je ne me suis peut être pas suffisament exprimer sur ma première demande, don je vais tenter d'améliorer.

    Lors du démarrage d'une base déployée sur plusieurs postes utilisateurs je fais des deleteobject de plusieurs tables, pour ensuite les réimporter, or, il arrive pour une raison X, que parfois les tables sont absentes au moment du démarrage, ce qui m'occasionne une erreur puisque je tente de supprimer quelque chose qui n'est pas présent.

    Jusque là il existait une macro pour réimporter manuellement ces tables, mais cela induisait que je devais me déplacer sur le poste en question et intervenir manuellement en, supprimant les tables pour éviter des redondances et lancer la macro des imports.

    Ma premiere idée était de faire simplement un réimport des tables et m'envoyer un mail pour m'avertir du poste qui avait eu ce probleme, mais au final il aurait toujours fallu me déplacer pour supprimer les tables réimportées qui étaient déjà présentes (réimport avec renommage MaTable et MaTable1)

    J'aurais pu chercher une solution qui tente à suprimer les table avec un caractere numerique à la fin, seulement il existe déjà dans cette base des tables avec des caracteres numeriques, donc pas possible non plus.

    Mais la solution je viens de la trouver grace à vous tout de même !
    est le cas vraiment parfait de ce que je recherchais comme solution, je l'avais déjà vu mais n'en comprennais pas toujours la subtilité. C'est chose faite maintenant !

    Donc merci à random et Tofalu !

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. message d'erreur pour supprimer une table
    Par marco361020 dans le forum Access
    Réponses: 4
    Dernier message: 22/11/2006, 17h22
  2. supprimer une table access avec sql
    Par xence dans le forum Langage SQL
    Réponses: 2
    Dernier message: 03/11/2006, 11h51
  3. [PL/SQL] Procédure SQL qui supprime une table
    Par lenoil dans le forum Oracle
    Réponses: 3
    Dernier message: 21/08/2006, 13h15
  4. Réponses: 3
    Dernier message: 20/05/2006, 23h28
  5. supprimer une table qui a des quotes dans son nom
    Par kleenex dans le forum Access
    Réponses: 2
    Dernier message: 17/10/2005, 16h03

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