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 :

Champs d'une table numériques


Sujet :

Access

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    262
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 262
    Points : 100
    Points
    100
    Par défaut Champs d'une table numériques
    Bonjour,

    J'ai une table access dont les nom des champs sont numériques, par exemple :
    001 : VARCHAR
    002 : VARCHAR
    003_001 : VARCHAR
    003_002 : VARCHAR
    etc ...

    Lorsque je crée une requête stockée dans access, par exemple une requête INSERT, je fais ceci :

    INSERT INTO Truc (001, 002, 003_001, 003_002) VALUES (v_001, v_002, v_003_001, v_003_002)

    Je sauve la requête mais lorsque je la réouvre (ça ne se produit pas toujours la première fois que je la réouvre), je retrouve ma requête sous cette forme :

    INSERT INTO Truc (1, 2, 003_001, 003_002) VALUES (v_001, v_002, v_003_001, v_003_002)

    001 est transformé en 1 et 002 est transformé en 2 ! Forcément, ça ne correspond plus aux champs de la table et ça plante.

    Alors j'ai tenté de mettre ces champs entre crochets mais ce n'est pas mieux.

    Comment faire pour gérer les champs d'une table dont le nom est numérique ?
    Merci d'avance

    PS : je n'ai pas le choix, ils doivent s'appeler comme ça.

  2. #2
    Responsable
    Office & Excel


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 128
    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 128
    Points : 55 940
    Points
    55 940
    Billets dans le blog
    131
    Par défaut
    Essaie avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    insert into truc ('001','002', ...)
    Pierre Fauconnier

  3. #3
    Membre averti

    Profil pro
    Inscrit en
    Mai 2004
    Messages
    236
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 236
    Points : 310
    Points
    310
    Par défaut
    Tu peux essayer en mettant les noms entre [].

    En espérant t'avoir aidé.

  4. #4
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    262
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 262
    Points : 100
    Points
    100
    Par défaut
    Merci pour votre aide,

    Les crochets, ça ne fonctionne pas, il les supprime automatiquement lorsque je rouvre la requête.
    J'ai donc tenté les quotes. Lorsque je rouvre la requête, je retrouve ['001'] à la place de '001'.

    Mais en exécutant mon programme, une exception est levée et me dit
    "L'instruction INSERT INTO contient le nom de champ inconnu suivant : ''001''. Assurez-vous que vous avez correctement saisi le nom, puis recommencez l'opération.
    "

    Jusqu'à maintenant, je laissais les valeurs numériques et sauvegardais plusieurs fois (CTRL + S) et fermait la requête. Ca fonctionne mais j'ai pas intérêt à réouvrir la requête, voilà pourquoi ça m'embête.

    Merci

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    262
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 262
    Points : 100
    Points
    100
    Par défaut
    Est-il possible de créer ma requête insert à l'aide du mode création pour voir comment access gère ce cas ?

    Pour les SELECT, il met les champs entre crochets.

  6. #6
    Expert éminent sénior
    Avatar de Dolphy35
    Homme Profil pro
    Responsable Systemes d'Information
    Inscrit en
    Octobre 2004
    Messages
    4 373
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Responsable Systemes d'Information
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2004
    Messages : 4 373
    Points : 11 218
    Points
    11 218
    Par défaut
    Citation Envoyé par bart64
    Est-il possible de créer ma requête insert à l'aide du mode création pour voir comment access gère ce cas ?

    Pour les SELECT, il met les champs entre crochets.
    Salut,
    Oui c'est possible tu créer une requête ajout avec le générateur de requête pui tu passe la requête en mode SQL.

  7. #7
    Responsable
    Office & Excel


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 128
    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 128
    Points : 55 940
    Points
    55 940
    Billets dans le blog
    131
    Par défaut
    En réalisant cela, tu verras que Access se comporte de la même façon. J'ai testé via le générateur de requête et dans la plupart des cas, Access a agi comme tu le décris.

    Une fois, il a accepté d'ajouter, puis j'ai fermé la requête, je l'ai ouverte à novueau et passée en SQL, et Access a de nouveau modifié le nom des champs et renvoyé une erreur...

    ... A suivre ...

    Pierre

Discussions similaires

  1. Réponses: 8
    Dernier message: 21/08/2007, 00h20
  2. afficher tous les champs d'une table
    Par julio84 dans le forum ASP
    Réponses: 8
    Dernier message: 19/01/2005, 10h31
  3. changement de type pour un champ dans une table
    Par Missvan dans le forum PostgreSQL
    Réponses: 2
    Dernier message: 23/02/2004, 15h26
  4. Ordre des champs dans une table
    Par patapetz dans le forum Outils
    Réponses: 5
    Dernier message: 30/07/2003, 06h53
  5. Récupération des noms de champs d'une table
    Par Battomura dans le forum SQL
    Réponses: 2
    Dernier message: 24/03/2003, 10h00

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