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 :

Possibilité création de table de selection alimentée par formulaire+sousformulaire regroupant 3 tables [AC-2016]


Sujet :

Access

  1. #21
    Membre à l'essai
    Homme Profil pro
    Agronome
    Inscrit en
    Mars 2017
    Messages
    31
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Agronome
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Mars 2017
    Messages : 31
    Points : 15
    Points
    15
    Par défaut
    Bonjour Marot, Bonjour Tee,

    Lors de l'exécution de la requête VBA l'erreur suivante apparait et aucun résultat n'est ajouté dans la table [T_Selection_Leg_Prod_mem] :

    "L'erreur que j’obtiens est Erreur d'exécution '3134':
    Erreur de syntaxe dans l'instruction INSERT INTO."

    J'ai essayé de détourner l'erreur en faisant la requête UNION puis en récupérant les résultats pour les insérés avec la requête INSERT INTO mais l'erreur s'affiche toujours.
    Le code est le suivant:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    Sub SelectionIntermed( _
    ByVal strClefPrimaire As String, _
    Optional ByVal strTableSelection As String = "[T_Selection_Leg_Prod_mem]", _
    Optional ByVal strWhere As String = "")
     
    Dim StrSQL As String
    Dim StrUnionQuery As String
     
    StrUnionQuery = "SELECT [ID_Legume], [ID_Produit], [ID_Segment], [Selection] " _
    & "FROM [T_Select_Leg_Seg_ok] " _
    & "WHERE " & strWhere & "" _
    & " UNION ALL " _
    & "SELECT [ID_Legume], [ID_Produit],  Null as [ID_Segment], [Selection] " _
    & "FROM [T_Selection_Leg_Prod] " _
    & "WHERE " & strWhere
     
    StrSQL = "INSERT INTO " & strTableSelection & "([ID_Legume], [ID_Produit], [ID_Segment], [Selection]) FROM " & StrUnionQuery & "" _
    Il est mis en fonction lors de l'actualisation du champs ID_Produit.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Public Sub ID_Produit_AfterUpdate()
    Nom_Produit = ID_Produit.Column(1)
    Dim VarIDProd As Variant
    VarIDProd = Forms![F_Select_Leg_Prod_Seg]![ID_Produit].Column(0)
    InitialiserSelection "[T_Legumes]", "[ID_Legume]", "[T_Selection_Leg_Prod]", IIf(VarIDProd <> "", "[ID_Produit] = " & VarIDProd, "")
    Me.Form.SF_Select_Leg_Prod.Requery
    Me.Requery
    SelectionIntermed "[ID_Legume]", "[T_Selection_Leg_Prod_mem]", IIf(VarIDProd <> "", "[ID_Produit] = " & VarIDProd, "")
    Me.Form.SF_Select_Leg_Prod.Requery
    Me.Requery
    End Sub
    Le debug.Print strUnionQuery me donne exemple:
    SELECT [ID_Legume], [ID_Produit], [ID_Segment], [Selection] FROM [T_Select_Leg_Seg_ok] WHERE [ID_Produit] = 9 UNION ALL SELECT [ID_Legume], [ID_Produit], Null as [ID_Segment], [Selection] FROM [T_Selection_Leg_Prod] WHERE [ID_Produit] = 9
    et si je copie ce code dans une nouvelle requête en SQL il me donne bien les valeurs que je recherche pour ID_Produit = 9.

    Auriez vous une idée du bug?

    Bien cordialement
    Julien

  2. #22
    Expert éminent sénior
    Avatar de tee_grandbois
    Homme Profil pro
    retraité
    Inscrit en
    Novembre 2004
    Messages
    8 817
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Novembre 2004
    Messages : 8 817
    Points : 14 911
    Points
    14 911
    Par défaut
    bonsoir,
    il faut des parenthèses pour délimiter la requête UNION quand on l'utilise comme requête d'insertion:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    (SELECT [ID_Legume], [ID_Produit], [ID_Segment], [Selection] FROM [T_Select_Leg_Seg_ok] WHERE [ID_Produit] = 9 
     UNION ALL SELECT [ID_Legume], [ID_Produit], Null as [ID_Segment], [Selection]  FROM [T_Selection_Leg_Prod] WHERE [ID_Produit] = 9)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    StrUnionQuery = "(" & StrUnionQuery & ")"

  3. #23
    Membre à l'essai
    Homme Profil pro
    Agronome
    Inscrit en
    Mars 2017
    Messages
    31
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Agronome
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Mars 2017
    Messages : 31
    Points : 15
    Points
    15
    Par défaut
    Bonjour Tee,

    Encore merci pour le coup de main.

    Je tombe toujours sur une erreur en mettant les parenthèses que ce soit à l'expression complète à "(" &StrUnionQuery & ")" ou aux deux.

    Pour voir si cela marché en temps que requête simple j'ai copié le code obtenu dans le générateur de requête en SQL :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    INSERT INTO T_Selection_Leg_Prod_mem ( ID_Legume, ID_Produit, ID_Segment, Selection ) 
    FROM (SELECT T_Select_Leg_Seg_ok.[ID_Legume], T_Select_Leg_Seg_ok.[ID_Produit], T_Select_Leg_Seg_ok.[ID_Segment], T_Select_Leg_Seg_ok.[Selection]
    FROM T_Select_Leg_Seg_ok WHERE T_Select_Leg_Seg_ok.[ID_Produit]=40  
    UNION ALL 
    SELECT [ID_Legume], [ID_Produit],  Null as [ID_Segment], [Selection] FROM [T_Selection_Leg_Prod] WHERE ([ID_Produit] = 40);
    Le résultat est une erreur " Erreur de syntaxe dans l'instruction INSERT INTO".

    J'ai essayé dans ce code SQL de mettre soit entre parenthèses soit chacun des SELECT jusqu'au dernière argument et/ou l'expression SELECT UNION complète mais le résultat reste le même. J'ai aussi essayé sans le FROM après le INSERT INTO ... (FROM) mais le résultat est toujours la même erreur.

    En supprimant les parenthèses et tout ce qui suit le UNION ALL inclut je tombe sur une insertion comme je le souhaite..

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    INSERT INTO T_Selection_Leg_Prod_mem ( ID_Legume, ID_Produit, ID_Segment, Selection )
    SELECT T_Select_Leg_Seg_ok.ID_Legume, T_Select_Leg_Seg_ok.ID_Produit, T_Select_Leg_Seg_ok.ID_Segment, T_Select_Leg_Seg_ok.Selection
    FROM T_Select_Leg_Seg_ok
    WHERE (((T_Select_Leg_Seg_ok.ID_Produit)=40));
    je suis sous Access 2016.

    Savez vous ou est mon erreur?
    Bien cordialement.
    Julien

  4. #24
    Expert éminent sénior
    Avatar de tee_grandbois
    Homme Profil pro
    retraité
    Inscrit en
    Novembre 2004
    Messages
    8 817
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Novembre 2004
    Messages : 8 817
    Points : 14 911
    Points
    14 911
    Par défaut
    bonjour,
    Savez vous ou est mon erreur?
    non, on ne ne peut pas savoir puisque tu n'as pas posté le code modifié. Je veux bien croire que tu as fait comme j'ai dit, mais si cela ne fonctionne pas, cela peut être parce qu'une modification a été mal reportée.

    Je tombe toujours sur une erreur en mettant les parenthèses que ce soit à l'expression complète à "(" &StrUnionQuery & ")" ou aux deux.
    Il faut mettre les parenthèses uniquement au début et à la fin de la première clause SELECT de l'UNION et à la fin du dernier WHERE de la dernière clause SELECT.
    Regarde bien, il manque une parenthèse fermante (ajouté en rouge):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    INSERT INTO T_Selection_Leg_Prod_mem ( ID_Legume, ID_Produit, ID_Segment, Selection ) 
    FROM (SELECT T_Select_Leg_Seg_ok.[ID_Legume], T_Select_Leg_Seg_ok.[ID_Produit], T_Select_Leg_Seg_ok.[ID_Segment], T_Select_Leg_Seg_ok.[Selection]
    FROM T_Select_Leg_Seg_ok WHERE T_Select_Leg_Seg_ok.[ID_Produit]=40  
    UNION ALL 
    SELECT [ID_Legume], [ID_Produit],  Null as [ID_Segment], [Selection] FROM [T_Selection_Leg_Prod] WHERE ([ID_Produit] = 40));
    vérifie aussi que ID_Segment accepte la valeur nulle

  5. #25
    Membre à l'essai
    Homme Profil pro
    Agronome
    Inscrit en
    Mars 2017
    Messages
    31
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Agronome
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Mars 2017
    Messages : 31
    Points : 15
    Points
    15
    Par défaut
    Bonjour Tee,

    Je te remercie pour la correction. J'ai essayé de mettre le code comme tu me l'as indiqué mais l'erreur se maintient...Je vais coller les imprimes écrans que j'ai.

    Nom : RDT UNUION.png
Affichages : 120
Taille : 21,1 Ko

    Voici en VBA et la fenètre qui apparait lorsque je modifie le champs ID_produit (ce qui active mon code et modifie mon ID_Produit du WHERE sans problème).

    Nom : VBA RQT UNION.png
Affichages : 126
Taille : 212,0 Ko

    Je recolle aussi le VBA du après MAJ de ID_Produit qui active la requête.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Public Sub ID_Produit_AfterUpdate()
    Nom_Produit = ID_Produit.Column(1)
    Dim VarIDProd As Variant
    VarIDProd = Forms![F_Select_Leg_Prod_Seg]![ID_Produit].Column(0)
    InitialiserSelection "[T_Legumes]", "[ID_Legume]", "[T_Selection_Leg_Prod]", IIf(VarIDProd <> "", "[ID_Produit] = " & VarIDProd, "")
    Me.Form.SF_Select_Leg_Prod.Requery
    Me.Requery
    SelectionIntermed "[ID_Legume]", "[T_Selection_Leg_Prod_mem]", IIf(VarIDProd <> "", "[ID_Produit] = " & VarIDProd, "")
    Me.Form.SF_Select_Leg_Prod.Requery
    Me.Requery
    End Sub
    Est ce que vous savez où peut être l'erreur?

    Bien cordialement.
    Julien

  6. #26
    Expert éminent sénior
    Avatar de tee_grandbois
    Homme Profil pro
    retraité
    Inscrit en
    Novembre 2004
    Messages
    8 817
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Novembre 2004
    Messages : 8 817
    Points : 14 911
    Points
    14 911
    Par défaut
    OK, il manque quelque chose dans la requête INSERT
    remplace cette ligne:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    StrSQL = "INSERT INTO " & strTableSelection & "([ID_Legume], [ID_Produit], [ID_Segment], [Selection]) FROM " & StrUnionQuery & ""
    par:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    StrSQL = "INSERT INTO " & strTableSelection & "([ID_Legume], [ID_Produit], [ID_Segment], [Selection]) SELECT U.[ID_Legume], U.[ID_Produit], U.[ID_Segment], U.[Selection]  FROM (" & StrUnionQuery & ") as U ;"
    et supprime cette ligne:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    StrUnionQuery = "(" & StrUnionQuery & ")"

  7. #27
    Membre à l'essai
    Homme Profil pro
    Agronome
    Inscrit en
    Mars 2017
    Messages
    31
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Agronome
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Mars 2017
    Messages : 31
    Points : 15
    Points
    15
    Par défaut
    Bonjour Tee,

    Un très grand merci pour le coup de main, la requête marche enfin!!

    Très cordialement.
    Julien Brach

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

Discussions similaires

  1. [AC-2007] Table à 3 champs alimentée par un tableau croisé dynamique avec 2 champs calculés
    Par marcelisa2 dans le forum Requêtes et SQL.
    Réponses: 10
    Dernier message: 02/02/2017, 16h01
  2. liste déroulante alimente par les champs d'une table sql
    Par gribouille343 dans le forum Langage
    Réponses: 6
    Dernier message: 04/01/2011, 16h44
  3. afficher input en fonction d'un select alimenté par sql
    Par kate59 dans le forum Général JavaScript
    Réponses: 9
    Dernier message: 04/02/2009, 09h57
  4. [MySQL] Select alimenté par bdd
    Par TwAzO dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 09/06/2008, 09h40
  5. [AJAX] Click sur select alimenté par ajax plante ie
    Par Pgs dans le forum Général JavaScript
    Réponses: 8
    Dernier message: 08/04/2008, 10h45

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