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 :

"Comment proposer d'ajouter une valeur manquante dans la table source d'une liste déroulante ?" - Erreur 3134 [AC-2010]


Sujet :

VBA Access

  1. #1
    Membre à l'essai
    Homme Profil pro
    Copywriter
    Inscrit en
    Juillet 2013
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Copywriter
    Secteur : Service public

    Informations forums :
    Inscription : Juillet 2013
    Messages : 35
    Points : 21
    Points
    21
    Par défaut "Comment proposer d'ajouter une valeur manquante dans la table source d'une liste déroulante ?" - Erreur 3134
    Bonjour à tous,

    Je cherche à intégrer ce code VBA trouvé ici-même sur le site . J'ignore pourquoi, mais j'obtiens une erreur d'exécution '3134' : Erreur de syntaxe dans l'instruction INSERT TO.

    Voici le code tel qu'intégré dans ma DB :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Option Compare Database
     
    Private Sub Modifiable57_NotInList(NewData As String, Response As Integer)
    If MsgBox("Do you want to add " & NewData & " to the list of themes ?", _
                           vbYesNo + vbQuestion + vbDefaultButton2, "Ajout") = vbYes Then
            DoCmd.RunSQL "INSERT INTO T-ProjectTheme ( ProjectThemeTitle ) SELECT """ & NewData & """;"
            Response = acDataErrAdded
        Else
            Response = acDataErrContinue
            Modifiable57.Undo
        End If
    End Sub
    Le nom de ma table est pourtant correct et ProjectThemeTitle renvoie au champ texte qui est proposé par ma liste déroulante.

    La seule petite particularité éventuelle vient du fait que ma liste déroulante Modifiable57 est dépendante du résultat d'une autre liste déroulante Modifiable42. Je ne sais pas si ça a un lien.

    Merci d'avance pour tout piste utile. N'hésitez pas à me poser des questions si la situation n'est pas assez claire.

    Bien à vous tous,

    EDIT : Pour ceux qui viendraient à lire cette discussion, le problème vient du système de liste déroulante en cascade (plus d'info au message #8) : Modifiable42 préfiltre Modifiable57. Solution proposée au message #11 par madefemere.
    A cela s'ajoutait un problème de syntaxe. Solution proposée au message #5 par madefemere. Merci à lui.

  2. #2
    Expert éminent

    Homme Profil pro
    Inscrit en
    Mai 2012
    Messages
    3 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Madagascar

    Informations forums :
    Inscription : Mai 2012
    Messages : 3 840
    Points : 7 974
    Points
    7 974
    Par défaut
    Bonsoir,

    Peux-tu mettre les propriétés :
    -Contenu de ta liste déroulante
    -Colonne liée
    -Nombre de colonnes
    pour comprendre le pourquoi.

    Cordialement,
    Mandresy
    "Je ne sais qu'une chose, c'est que je ne sais rien" Socrate

    N'oublions pas de mettre quand on a trouvé notre bonheur. Soyons sympa pour les futurs heureux.

    Merci, c'est toujours sympa de recevoir des de votre part

  3. #3
    Membre à l'essai
    Homme Profil pro
    Copywriter
    Inscrit en
    Juillet 2013
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Copywriter
    Secteur : Service public

    Informations forums :
    Inscription : Juillet 2013
    Messages : 35
    Points : 21
    Points
    21
    Par défaut
    Bonsoir Madefemere,

    Je te transmets les informations dès demain matin (fichier sur le PC du boulot).

    Merci déjà de te pencher sur mon problème.

    Excellente soirée.

    Cordialement,

  4. #4
    Membre à l'essai
    Homme Profil pro
    Copywriter
    Inscrit en
    Juillet 2013
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Copywriter
    Secteur : Service public

    Informations forums :
    Inscription : Juillet 2013
    Messages : 35
    Points : 21
    Points
    21
    Par défaut
    Bonjour,

    Voici le complément d'information demandé :

    Le contenu de ma liste déroulante (Modifiable57) est basé sur une requête exprimée comme suit :

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT [T-ProjectTheme].[N°], [T-ProjectTheme].[ProjectThemeTitle] FROM [T-ProjectTheme] WHERE [T-ProjectTheme].[AGNum]= Forms![F-Action].[Modifiable42];

    Modifiable57 comprend 2 colonnes (la première étant masquée) :
    [T-ProjectTheme].[N°] : la valeur à enregistrer
    [T-ProjectTheme].[ProjectThemeTitle] : la valeur à afficher

    A tout hasard, je joins un printscreen de mes relations. Toujours utile pour avoir une vue d'ensemble.

    Nom : Rel.jpg
Affichages : 243
Taille : 42,3 Ko

    Cordialement,

  5. #5
    Expert éminent

    Homme Profil pro
    Inscrit en
    Mai 2012
    Messages
    3 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Madagascar

    Informations forums :
    Inscription : Mai 2012
    Messages : 3 840
    Points : 7 974
    Points
    7 974
    Par défaut
    Bonjour,

    Ton problème est lié aux noms de tes tables. TU utilises "-" qui crée une erreur dans les codes SQL si les noms des tables ne sont pas entre [].
    Modifies les noms de tes tables en utilisant "_" (tiret 8) au lieu du signe de soustraction.
    Sinon mets tes noms de tables entre [].

    Cordialement,
    Mandresy
    "Je ne sais qu'une chose, c'est que je ne sais rien" Socrate

    N'oublions pas de mettre quand on a trouvé notre bonheur. Soyons sympa pour les futurs heureux.

    Merci, c'est toujours sympa de recevoir des de votre part

  6. #6
    Membre à l'essai
    Homme Profil pro
    Copywriter
    Inscrit en
    Juillet 2013
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Copywriter
    Secteur : Service public

    Informations forums :
    Inscription : Juillet 2013
    Messages : 35
    Points : 21
    Points
    21
    Par défaut
    Bonjour,

    J'ai essayé en ajoutant les [] autour de ma table dans le SQL, mais ça ne fonctionne pas.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Private Sub Modifiable57_NotInList(NewData As String, Response As Integer)
    If MsgBox("Do you want to add " & NewData & " to the list of themes ?", _
                           vbYesNo + vbQuestion + vbDefaultButton2, "Ajout") = vbYes Then
            DoCmd.RunSQL "INSERT INTO [T-ProjectTheme] ( ProjectThemeTitle ) SELECT """ & NewData & """;"
            Response = acDataErrAdded
        Else
            Response = acDataErrContinue
            Modifiable57.Undo
        End If
    End Sub
    En revanche,si j'isole SQL dans une requête d'ajout, là, ça fonctionne sans problème.

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    INSERT INTO [T-ProjectTheme] ( ProjectThemeTitle )
    SELECT "Test" AS Expr1;

    Je crois qu'on a quand même résolu quelque chose avec les [] car je n'ai plus une erreur de syntaxe, mais une erreur "Le texte entré n'est pas un élément de la liste".

    Je fais le test en changeant mes "-" par des "_" dans les noms de table.

  7. #7
    Expert éminent

    Homme Profil pro
    Inscrit en
    Mai 2012
    Messages
    3 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Madagascar

    Informations forums :
    Inscription : Mai 2012
    Messages : 3 840
    Points : 7 974
    Points
    7 974
    Par défaut
    Bonjour,

    Je ne sais pas si tes relations avec les autres tables a une incidence mais ci-joint la bd exemple que j'ai testée :Pièce jointe 170786

    Cordialement,
    Mandresy
    "Je ne sais qu'une chose, c'est que je ne sais rien" Socrate

    N'oublions pas de mettre quand on a trouvé notre bonheur. Soyons sympa pour les futurs heureux.

    Merci, c'est toujours sympa de recevoir des de votre part

  8. #8
    Membre à l'essai
    Homme Profil pro
    Copywriter
    Inscrit en
    Juillet 2013
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Copywriter
    Secteur : Service public

    Informations forums :
    Inscription : Juillet 2013
    Messages : 35
    Points : 21
    Points
    21
    Par défaut
    Etant donné que je constate que ce code fonctionne en situation "normale" et en y réfléchissant davantage, j'en arrive à la conclusion qu'il y a effectivement un conflit entre la requête derrière ma liste déroulante Modifiable57 et le code VBA.

    Que fait Modifiable57 ? Il renvoie les thèmes (ProjectTheme) liés à l'administration (AG) qui est sélectionnée en Modifiable42.
    Que fait le VBA ? Il ajoute un thème si celui-ci ne fait pas partie de la liste préfiltrée par Modifiable57. Mais il l'ajoute sans spécifier quelle administration lui est associée. Donc, il lui est impossible d'appartenir à la liste filtrée par Modifiable57.

    Ne faudrait-il pas en fait préciser au VBA d'aller mettre le numéro de l'AG sélectionnée en Modifiable42 dans la colonne AGNum de la table ProjectTheme au même niveau que la nouvelle valeur ProjectThemeTitle ?

    Si la DB est souhaitée, faites-moi signe.

  9. #9
    Expert éminent

    Homme Profil pro
    Inscrit en
    Mai 2012
    Messages
    3 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Madagascar

    Informations forums :
    Inscription : Mai 2012
    Messages : 3 840
    Points : 7 974
    Points
    7 974
    Par défaut
    Bonsoir,

    A priori non pour la première supposition vu la structure de ta base de données.
    Peux-tu poster effectivement la base compactée, zippée et anonymisée et version en mdb stp.

    Cordialement,
    Mandresy
    "Je ne sais qu'une chose, c'est que je ne sais rien" Socrate

    N'oublions pas de mettre quand on a trouvé notre bonheur. Soyons sympa pour les futurs heureux.

    Merci, c'est toujours sympa de recevoir des de votre part

  10. #10
    Membre à l'essai
    Homme Profil pro
    Copywriter
    Inscrit en
    Juillet 2013
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Copywriter
    Secteur : Service public

    Informations forums :
    Inscription : Juillet 2013
    Messages : 35
    Points : 21
    Points
    21
    Par défaut
    Voici madefemere.

    Il y a quand même un détail qui me dérange dans ma DB. C'est le AGNum (champ numérique) qui appartient à la table T-ProjectTheme et qui n'est lié à rien. En fait, je l'ai mis pour associer un ProjectTheme à une AG, mais ça ne me parait pas très orthodoxe.

    Au plaisir de te lire.
    Fichiers attachés Fichiers attachés

  11. #11
    Expert éminent

    Homme Profil pro
    Inscrit en
    Mai 2012
    Messages
    3 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Madagascar

    Informations forums :
    Inscription : Mai 2012
    Messages : 3 840
    Points : 7 974
    Points
    7 974
    Par défaut
    Bonjour,

    Effectivement, le deuxième champ posait problème.
    Il fallait modifier le code d'insertion en conséquence :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DoCmd.RunSQL "INSERT INTO [T-ProjectTheme] ( ProjectThemeTitle,AGNum ) SELECT """ & NewData & """," & Me.Modifiable42 & ";"
    Cordialement,
    Mandresy
    "Je ne sais qu'une chose, c'est que je ne sais rien" Socrate

    N'oublions pas de mettre quand on a trouvé notre bonheur. Soyons sympa pour les futurs heureux.

    Merci, c'est toujours sympa de recevoir des de votre part

  12. #12
    Membre à l'essai
    Homme Profil pro
    Copywriter
    Inscrit en
    Juillet 2013
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Copywriter
    Secteur : Service public

    Informations forums :
    Inscription : Juillet 2013
    Messages : 35
    Points : 21
    Points
    21
    Par défaut
    Voilà, ça marche parfaitement à présent. C'était exactement le petit bout de code qui me manquait.

    Je te remercie infiniment.

    EDIT : En fait, cela fonctionne quand je suis dans un enregistrement, mais du coup impossible d'ajouter un nouvel enregistrement dans ma table T-Action.
    Le message d'erreur est : Vous ne pouvez pas ajouter ou modifier un enregistrement car l'enregistrement associé est requis dans la table "T-ProjectTheme".

    EDIT2 : J'ai repris ma structure "from scratch" et ça fonctionne à présent parfaitement. Problème de relation quelque part.

    Cordialement,

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 08/07/2014, 14h17
  2. Ajouter une valeur manquante dans une liste déroulante
    Par fremarnat dans le forum VBA Access
    Réponses: 0
    Dernier message: 05/11/2013, 15h24
  3. [WD12] Info manquante dans le code source d'une page web
    Par zouzoukha dans le forum WinDev
    Réponses: 12
    Dernier message: 18/06/2012, 04h21
  4. Réponses: 2
    Dernier message: 04/06/2010, 21h53
  5. Réponses: 12
    Dernier message: 27/08/2007, 11h34

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