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 Record si la case à cocher est décochée


Sujet :

Access

  1. #1
    Membre à l'essai
    Homme Profil pro
    Collégien
    Inscrit en
    Décembre 2016
    Messages
    53
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Collégien
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2016
    Messages : 53
    Points : 21
    Points
    21
    Par défaut Supprimer Record si la case à cocher est décochée
    Bonjour,

    J'ai besoin d'un code pour supprimer un enregistrement d'un table si une case a coucher d'une autre table est découcher.
    j'ai utiliser ce code ci dessous, et il est bien fonctionner on cas de ajouter les données dans la table si j'ai coucher une enregistrement.
    Mais leur de découcher la case a coucher, j'ai besoin que le code supprime seulement l'enregistrement a qui j'ai découcher la case a coucher, est ne pas tous les enregistrement de la table picking

    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
    18
    19
    20
    Private Sub Livrer_AfterUpdate()
    If Livrer = -1 Then
    DoCmd.RefreshRecord
    Dim Sql As String
        Sql = " INSERT INTO Picking ( Label ) " _
             & "SELECT Reception.Label " _
             & "FROM [Reception] " _
             & "WHERE (((Reception.Livrer)=Yes));"
        DoCmd.RunSQL Sql
        DoCmd.SetWarnings False
        Else
        Dim Sql2 As String
    Sql2 = "DELETE Picking.Label " _
        & "FROM Picking " _
        & "WHERE (((Reception.Livrer)= no));"
      DoCmd.RunSQL Sql2
        DoCmd.SetWarnings False
        End If
     
    End Sub
    la table ciblé est : Picking, avec un seul champ : Label

    Nom : 2017-11-07 (2).png
Affichages : 260
Taille : 2,1 Ko


    le Formulaire:

    Nom : 2017-11-07 (1).png
Affichages : 323
Taille : 50,2 Ko

    Merci d'avance
    Images attachées Images attachées  

  2. #2
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 331
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 331
    Points : 23 786
    Points
    23 786
    Par défaut
    Bonjour.

    Ton problème vient du fait que tu n'as pas spécifier quel label devait être supprimé.
    Tu peux probablement le faire en faisant une jointure entre ta table Picking et ta table Reception.
    Soit utiliser un DFirst()

    A+
    Vous voulez une réponse rapide et efficace à vos questions téchniques ?
    Ne les posez pas en message privé mais dans le forum, vous bénéficiez ainsi de la compétence et de la disponibilité de tous les contributeurs.
    Et aussi regardez dans la FAQ Access et les Tutoriaux Access. C'est plein de bonnes choses.

  3. #3
    Candidat au Club
    Femme Profil pro
    Analyste programmeur
    Inscrit en
    Novembre 2010
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Analyste programmeur

    Informations forums :
    Inscription : Novembre 2010
    Messages : 2
    Points : 3
    Points
    3
    Par défaut Réponse
    A mon avis, tu veux mettre le champ à blanc et non pas supprimer l'enregistrement

    Il faut commencer par créer la requête souhaitée, s'il y a deux tables,on en tient compte
    Ensuite, on récupère le SQL
    Après, on modifie le SQL selon les critères souhaités

    Sql2 = "UPDATE Picking SET Picking.Label = Null WHERE (((Picking.Livrer)= False))"
    DoCmd.RunSQL Sql2

    Bonne soirée

  4. #4
    Membre à l'essai
    Homme Profil pro
    Collégien
    Inscrit en
    Décembre 2016
    Messages
    53
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Collégien
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2016
    Messages : 53
    Points : 21
    Points
    21
    Par défaut Supprimer Record si la case à cocher est décochée
    Bonjour Tous, et Merci de votre retour.

    Pour la jointure, j'ai éssyer avec ce code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sql = "DELETE Picking.Label, Reception.Livrer FROM Picking INNER JOIN Reception ON Picking.Label = Reception.Label WHERE (((Reception.Livrer)=No));"
    mais le code et ce bloqué, et j'avoir une message d'erreur

    : Nom : 2017-11-09 (1).png
Affichages : 255
Taille : 23,9 Ko.


    Et pour la deuxième solution proposer par Mr izonette , aucun changement n'a apporter sur la table.

    Saluations

    dellal

  5. #5
    Membre à l'essai
    Homme Profil pro
    Collégien
    Inscrit en
    Décembre 2016
    Messages
    53
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Collégien
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2016
    Messages : 53
    Points : 21
    Points
    21
    Par défaut
    Bonjour,

    J'ai résolu le problème suite a une exemple que j'ai le trouver sur ce cite, le code complet est comme ce de suite:

    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
    Private Sub Livrer_AfterUpdate()
    DoCmd.RefreshRecord
    Dim Sql As String
        Sql = " INSERT INTO Picking ( Label ) " _
             & "SELECT Reception.Label " _
             & "FROM [Reception] " _
             & "WHERE (((Reception.Livrer)=Yes));"
        DoCmd.RunSQL Sql
        DoCmd.SetWarnings False
    Dim Sql2 As String
        Sql2 = "DELETE [Picking].Label, * " _
             & "FROM [Picking] WHERE ((([Picking].label) In (SELECT [Picking].label " _
             & "FROM [Picking] LEFT JOIN [Reception] ON [Picking].label = [Reception].label " _
             & "WHERE ((([Reception].Livrer)=0)))));"
        DoCmd.RunSQL Sql2
        DoCmd.SetWarnings False
    End Sub
    Merci de votre support encore.

    DELLAL

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

Discussions similaires

  1. [AC-2013] iif (somme de valeur si ma case à cocher est cochée
    Par dellalyoussef dans le forum Access
    Réponses: 2
    Dernier message: 31/10/2017, 17h07
  2. Réponses: 2
    Dernier message: 22/10/2015, 21h58
  3. case cocher ou décocher
    Par hanou88 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 06/09/2013, 22h02
  4. Cases à cocher et décocher en cascade
    Par WAS92 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 16/06/2011, 17h14

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