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 :

Tables liées et champs multivalués


Sujet :

Access

  1. #1
    Membre régulier
    Homme Profil pro
    Manager de projet (retraité)
    Inscrit en
    Juillet 2010
    Messages
    150
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Manager de projet (retraité)

    Informations forums :
    Inscription : Juillet 2010
    Messages : 150
    Points : 71
    Points
    71
    Par défaut Tables liées et champs multivalués
    Bonjour,

    J’ai développé une application monoposte avec Access 2010 tournant sous Win 7 puis l’ai dupliquée dans plusieurs répertoires afin de l’utiliser avec des données différentes. Chaque base a un nom de fichier différent. No pb.

    Pour des raisons de performances et de maintenance, j’ai fractionné chacune de ces bases. No pb.

    J’ai voulu aller plus loin pour n’avoir qu’un seul moteur frontal à maintenir et à copier dans chaque répertoire et là ça coince : que ce soit en manuel (en précisant bien le nouvel emplacement) ou via VBA, le processus d’attachement des tables liées plante pour 4 tables parmi 32.

    1er type de problème : pour 3 tables le message d’erreur est de la forme « [D:\..._be.accdb]tblAtblB » n’est pas un nom valide. Or les tables tblA et tblB existent et sont en relation ayant pour clé étrangère un champ multivalué. Est-ce la cause ?

    2ème type de problème : la 4ème table (tblC) isolée génère le message « Le moteur de base de données Access n’ pas pu trouver l’objet tblC ». A priori aucune particularité détectée.

    J’ai cherché dans des forums mais rien qui ressemble à ça, alors si vous avez un avis ….
    Merci d’avance. Bien cordialement.

  2. #2
    Rédacteur/Modérateur
    Avatar de loufab
    Homme Profil pro
    Entrepreneur en solutions informatiques viables et fonctionnelles.
    Inscrit en
    Avril 2005
    Messages
    12 017
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Entrepreneur en solutions informatiques viables et fonctionnelles.
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2005
    Messages : 12 017
    Points : 24 548
    Points
    24 548
    Par défaut
    Bonjour,

    Problème étrange !

    Tu fais ton attachement via le menu ?
    Par code VBA ?
    -avec la propriété Connect
    -avec un suppression d'attache

    Essaye de supprimer tes attaches , compacte puis recrée tes attaches.

    Cordialement,

  3. #3
    Membre régulier
    Homme Profil pro
    Manager de projet (retraité)
    Inscrit en
    Juillet 2010
    Messages
    150
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Manager de projet (retraité)

    Informations forums :
    Inscription : Juillet 2010
    Messages : 150
    Points : 71
    Points
    71
    Par défaut
    Bonjour Loufab et merci de te pencher sur ce problème effectivement étrange, pour ne pas dire irritant. En effet il se manifeste aussi bien manuellement (menu Gestionnaire de tables liées) qu’en VBA.

    Voici le détail de ce que j’ai fait :
    1. Développement de l’application dans le répertoire Dir1 sous le nom A1,
    2. Copie de l’application dans le répertoire Dir2 sous le nom A2,
    3. Fractionnement de la base A1 dans Dir1, ce qui donne les fichiers A1.accdb et A1_be.accdb,
    4. Idem pour A2 dans Dir2, ce qui donne A2.accdb et A2_be.accdb.

    Jusque là tout va bien. Ensuite, pour des raisons d’économie de maintenance, je copie A1.accdb dans Dir2 et tente de lui rattacher les tables de A2_be.accdb en indiquant le nouvel emplacement au gestionnaire de tables.

    C’est là que ça plante comme indiqué dans le 1er message. Pour aller plus loin j’ai tenté l’approche par fonction de rattachement VBA :
    - à la première itération tdf.Connect contient bien « ;DATABASE=D:\Dir2\A2_be.accdb;TABLE=tblTable1
    - mais le tdf.ResfreshLink qui suit plante avec le message :[D:\Dir1\A1_be.accdb].tblTable1tblTable2 n’est pas un nom valide etc …

    Ce qui est bizarre c’est que :
    - RefreshLink invoque à tort Dir1 et A1_be bien que Connect contienne Dir2 et A2_be,
    - le message d’erreur concatène le nom tblTable2 à celui de tblTable1 qui est en cours de traitement (je rappelle que tblTable1 pointe sur tblTable2 via un champ multivalué, mais je ne vois pas pourquoi ça interviendrait dans ce problème).

    Enfin et pour répondre à ta suggestion concernant le détachement des tables, je dois mal m'y prendre car ça ne marche pas. Je n'ai pas trouvé d'exemple autre que modifier le rattachement, ce qui est justement mon problème. Peux-tu m'indiquer comment faire ?

    Merci d'avance.

Discussions similaires

  1. [AC-2003] Table Liée - Oubli champ et données
    Par ALEX80800 dans le forum Access
    Réponses: 4
    Dernier message: 20/11/2012, 15h53
  2. Etat basé sur une table avec 2 champs multivalués
    Par amphytria dans le forum Modélisation
    Réponses: 20
    Dernier message: 08/09/2007, 14h26
  3. Table liée - ajout champ
    Par jeanjean0403 dans le forum Modélisation
    Réponses: 12
    Dernier message: 06/07/2007, 13h23
  4. Réponses: 4
    Dernier message: 27/01/2006, 16h38
  5. [select dans case] reconnaitre un champ d une table liée
    Par the_edge dans le forum MS SQL Server
    Réponses: 14
    Dernier message: 22/10/2004, 16h47

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