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

IHM Discussion :

supprimer enregistrement par rapport à zone de texte.


Sujet :

IHM

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    27
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 27
    Points : 17
    Points
    17
    Par défaut supprimer enregistrement par rapport à zone de texte.
    Bonjour,

    Je pense que ça doit être simple à faire vu que je n'ai pas trouver la réponse sur le forum, mais si quelqu'un peut m'aider ce serait sympe.

    J'ai un formulaire, avec d'une part un sous formulaire affichant ma table dimension (JLP_Dimension_mm_pouce) et d'autre part une zone de text (txt_idauto)

    Je voudrais supprimer un enregistrement de ma table en fonction de ma zone de texte, en cliquant sur un bouton de commande.

    Je precise que je suis sur Access 2003 et que ma table est une table liée à SQL Server

    Voici le code de mon bouton

    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
    21
    22
    23
    24
    25
    26
    Private Sub cmd_supp_Click()
     
    Dim AMETIS_ACCESS As DAO.Database
    Dim rst As DAO.Recordset
     
    Dim txt_idauto As String
     
    Set AMETIS_ACCESS = Application.CurrentDb
    Set rst = AMETIS_ACCESS.OpenRecordset("JLP_Dimension_mm_pouce", dbOpenDynaset)
     
    rst.MoveFirst
     
    If Me.txt_idauto <> "" Then
     
        DoCmd.RunSQL "Delete * From JLP_Dimension_mm_pouce where (rst![idauto]=txt_idauto.value)"
     
    End If
     
    Exit_cmd_supp_Click:
        Exit Sub
     
    Err_cmd_supp_Click:
        MsgBox Err.Description
        Resume Exit_cmd_supp_Click
     
    End Sub
    Dîtes moi ce qui ne va pas.
    Merci d'avance

  2. #2
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    27
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 27
    Points : 17
    Points
    17
    Par défaut
    J'ai modifié mon code :

    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
    21
    22
    23
    24
    25
    26
    27
    28
    Private Sub cmd_supp_Click()
     
    Dim AMETIS_ACCESS As DAO.Database
    Dim rst As DAO.Recordset
     
    Dim idauto As Integer
     
    Set AMETIS_ACCESS = Application.CurrentDb
    Set rst = AMETIS_ACCESS.OpenRecordset("JLP_Dimension_mm_pouce", dbOpenDynaset)
     
    rst.MoveFirst
     
    idauto = txt_idauto
     
    If Me.txt_idauto <> "" Then
     
        DoCmd.RunSQL "Delete * From JLP_Dimension_mm_pouce where [idauto]"
     
    End If
     
    Exit_cmd_supp_Click:
        Exit Sub
     
    Err_cmd_supp_Click:
        MsgBox Err.Description
        Resume Exit_cmd_supp_Click
     
    End Sub
    Et j'ai le message d'erreur suivant :
    "Erreur d'exécution "3086" : Impossible de supprimer dans les tables spécifiées"

    Donc à mon avis c'est parce que je n'ai pas tous les droits quand ma table Access est liée à SQL server.

    Je vous dirais si ça marche quand j'aurais les droits.

    Aurélie

  3. #3
    Modérateur
    Avatar de Chtulus
    Homme Profil pro
    Ingénieur
    Inscrit en
    Avril 2008
    Messages
    3 094
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Santé

    Informations forums :
    Inscription : Avril 2008
    Messages : 3 094
    Points : 8 678
    Points
    8 678
    Par défaut
    Bonjour,

    En effet cela peu être liéé à des problème de droits, mais il te mettrais surement plus un message du style, "Permissions denied" !

    En revanche mopi je passe par le code 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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
     
    Private Sub Button1_Click()
     
    'Déclaration des variables
    Dim cnx As New ADODB.Connection
    Dim rst As New ADODB.Recordset
     
     
    'Instantation variable connexion
    Set cnx = New ADODB.Connection
     
    'Description de la chaine de connexion
    cnx.ConnectionString = "Provider = sqloledb ; " & _
                           "Data Source = NomServeurSQL ; " & _
                           "Initial catalog = NomBaseDonnée ; " & _
                            "User ID = IDutilisateur ; " & _
                            "Password = PWDutilisateur ; "
     
    'Ouverture de la connection
    cnx.Open
     
    'Si état de la connexion = ouverte
     If cnx.State = adStateOpen Then
     
     
        'On ouvre le record de la requête
        rst.Open "SELECT TonChamps " _
                     & " FROM TaTable " _
                       & " WHERE TonChamps = '" & Forms!NomFormulaire!NomChamps & "' ;", cnx
     
    ' Puis finir le traitement...

  4. #4
    Membre actif
    Homme Profil pro
    Développeur Java
    Inscrit en
    Mai 2008
    Messages
    221
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2008
    Messages : 221
    Points : 244
    Points
    244
    Par défaut
    Ta requête ne doit pas être correcte.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    "Delete * From JLP_Dimension_mm_pouce where [idauto]"
    Where [idauto] ??
    Il y a un problème dans ta clause where
    je pense plus a un truc du genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    "Delete * From JLP_Dimension_mm_pouce where [nom du champ id de ta table] = " & idauto & ";"
    La ca me parait un peu mieux
    Voila essaye et tiens nous au courant !

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    27
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 27
    Points : 17
    Points
    17
    Par défaut
    Merci pour vos réponses, j'ai fais les changement pour la connection à la base SQL, et j'ai toujours le même message.

    J'ai testé une requête de suppression directement avec access et c'est le même message, et même en accédant directement à ma table par access je ne peux rien faire (ni modifier, ni supprimer)

    Je vais voir si on me donne les droits nécessaires. Et vous tiens au courant pour la suite.

    Merci à vous.
    Aurélie

  6. #6
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    27
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 27
    Points : 17
    Points
    17
    Par défaut
    Bonjour,

    Voila où j'en suis, j'ai trouvé pourquoi je ne pouvais pas écrire sur ma table, au moment de lier la table, il fallait que je choisisse un index unique.

    Voila le code que j'ai finalement mis et il fonctionne.
    Apparement je n'ai pas besoin d'ouvrir de connection.

    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
    21
    22
    23
    24
    25
     
    Private Sub cmd_supp_Click()
     
    Dim id As Integer
     
        If txt_idauto.Value <> "" Then
           id = txt_idauto.Value
           DoCmd.RunSQL "Delete * From JLP_Dimension_mm_pouce where [idauto] = " & id & ";" '
           MsgBox "Vous aller supprimmer la ligne " & id & " !", vbOKOnly
        Else
           MsgBox "Veuillez saisir un numéro id !", vbOKOnly
        End If
     
    txt_idauto.Value = ""
     
        Me.Refresh
     
    Exit_cmd_supp_Click:
        Exit Sub
     
    Err_cmd_supp_Click:
        MsgBox Err.Description
        Resume Exit_cmd_supp_Click
     
    End Sub

    Merci à vous.
    Aurélie

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

Discussions similaires

  1. Réponses: 6
    Dernier message: 25/08/2008, 12h27
  2. Source d'enregistrement d'une zone de texte dans un état
    Par beabzh dans le forum VBA Access
    Réponses: 4
    Dernier message: 30/07/2007, 12h22
  3. Afficher les enregistrements par rapport à un caractère saisi
    Par issam47 dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 05/06/2007, 16h16
  4. Récupérer le numéro d'enregistrement dans une zone de texte
    Par The_Super_Steph dans le forum VBA Access
    Réponses: 18
    Dernier message: 16/05/2007, 08h50
  5. Réponses: 2
    Dernier message: 26/04/2007, 11h52

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