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 :

Verifier existance donnée avant requete insertion


Sujet :

VBA Access

  1. #1
    Membre à l'essai
    Homme Profil pro
    Webmaster
    Inscrit en
    Mai 2016
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mai 2016
    Messages : 15
    Points : 10
    Points
    10
    Par défaut Verifier existance donnée avant requete insertion
    Bonjour,

    Dans ma base de donnée j'arrive a inserer des valeurs dans une table saison. Ce que je voudrais est de savoir si ces valeurs sont déja présente afin des les insérer ou non.
    Voici mon code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    Dim db As DAO.Database
    Set db = CurrentDb
     
     
    Dim ssql  As String
        ssql = "INSERT INTO tSaisons (IdAdh,Saison) values (IdL,[Formulaires]![fAdherents]![Licencesf]![Saison])"
     
    DoCmd.RunSQL ssql
    Forms("fAdherents").Refresh
    Merci d'avance pour votre aide.

  2. #2
    Invité
    Invité(e)
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    INSERT INTO tSaisons (INSERT INTO tSaisons (IdAdh,Saison) values (IdL,[Formulaires]![fAdherents]![Licencesf]![Saison]) values (IdL,[Formulaires]![fAdherents]![Licencesf]![Saison]) from tsaison left join (select Idlt from tSason where  IdAdh=IdL,Saison=[Formulaires]![fAdherents]![Licencesf]![Saison]) as sais on sais.IdAdh= tSaison.IdAdh where Sais.IdAdh is null
    
    Dernière modification par Invité ; 23/03/2017 à 17h57.

  3. #3
    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.

    Tu peux le faire ainsi :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    dim nbInfo as long:dcount("Id", "tSaison", "[IdAdh]=" & IdL & " and [Saison]=" & [Forms]![fAdherents]![Licencesf].Form.[Saison])
     
    if nbInfo=0 then
       'ici ton code d'ajout
    end if
    Et tu peux aussi laisser Access s'en occuper en définissant un index unique composé de [IdAdh] et [Saison].
    Si l'enregistrement existe déjà Access ne le créera simplement pas.

    aussi tu pourrais écrire :

    call db.execute(sql) à la place du doCmd.RunSQL ce qui te dispense de neutraliser les alertes d'insertion de Access.

    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.

  4. #4
    Membre à l'essai
    Homme Profil pro
    Webmaster
    Inscrit en
    Mai 2016
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mai 2016
    Messages : 15
    Points : 10
    Points
    10
    Par défaut
    Bonsoir,

    Merci pour vos réponse je teste cela des que possible.
    Eric

  5. #5
    Membre à l'essai
    Homme Profil pro
    Webmaster
    Inscrit en
    Mai 2016
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mai 2016
    Messages : 15
    Points : 10
    Points
    10
    Par défaut
    Rebonsoir,

    Je viens de tester le code de dysorthographie. Il semble qu'il y a une erreur de synrtaxe car la ligne de code est en rouge et cela me donne une erreur 3431 erreur de syntaxe dans l'instruction insert into

    Pour le code de marot_r j'ai aussi une erreur de syntaxe sur la ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
     
    dim nbInfo as long:dcount("Id", "tSaison", "[IdAdh]=" & IdL & " and [Saison]=" & [Forms]![fAdherents]![Licencesf].Form.[Saison])

  6. #6
    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
    Oops !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    dim nbInfo as long:nbInfo =dcount("Id", "tSaison", "[IdAdh]=" & IdL & " and [Saison]=" & [Forms]![fAdherents]![Licencesf].Form.[Saison])
    Et il se peut que la syntaxe de "[IdAdh]=" & IdL & " and [Saison]=" & [Forms]![fAdherents]![Licencesf].Form.[Saison] ne soit pas parfaite car je ne connais pas ton appli.
    L'idée est de vérifier le nombre d'éléments qui vont être mis à jour donc le critère doit être indentique à celui du INSERT.

    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.

  7. #7
    Membre à l'essai
    Homme Profil pro
    Webmaster
    Inscrit en
    Mai 2016
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mai 2016
    Messages : 15
    Points : 10
    Points
    10
    Par défaut
    Bonjour,

    Merci marot_r pour ta réponse je vais tester cela.

    Mon appli est dispo sur une autre discussion ouverte sur la gestion des saisons club ping pong.
    https://www.developpez.net/forums/d1...lub-ping-pong/

    Eric

  8. #8
    Membre à l'essai
    Homme Profil pro
    Webmaster
    Inscrit en
    Mai 2016
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mai 2016
    Messages : 15
    Points : 10
    Points
    10
    Par défaut
    Bonjour,

    J'ai résolu mon problème grâce au différents échanges.
    Voici le code que j'ai mis.
    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
    32
    33
    34
    35
    36
     
    Dim db As DAO.Database
    Set db = CurrentDb
     
    S = Me.Saison
    Dim ssql  As String
     
     ' ===== déclaration des variables =====
        Dim strSQL As String
        Dim rst As DAO.Recordset
     
        ' ===== affectation =====
     
     
       strSQL = "SELECT tSaisons.Saison, tSaisons.IdAdh FROM tSaisons WHERE (tSaisons.Saison='" & S & "') and (IdAdh=" & IdL & ")"
     
        Set rst = CurrentDb.OpenRecordset(strSQL)
        If rst.RecordCount = 0 Then
     
               ssql = "INSERT INTO tSaisons (IdAdh,Saison) values (IdL,[Formulaires]![fAdherents]![Licencesf]![Saison])"
               DoCmd.RunSQL ssql
     
        Else
     
        End If
     
        ' ===== libération =====
        rst.Close
        Set rst = Nothing
     
     
    Forms("fAdherents").Refresh
     
     
     
    End Sub
    Cela donne le résultat que j'attendais. Certains d'entre vous aurez peut être fait mieux, mais comme je ne suis pas calé cela me satisfait.
    Merci pour votre aide.

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

Discussions similaires

  1. [MySQL] requete pour verifier la presence d'une donnée avant de l'inserer
    Par Krabbos dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 31/05/2011, 16h23
  2. [MySQL] Vérifier si un ligne existe déjà dans la base de données avant l'insertion
    Par moukit233 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 11/08/2009, 12h35
  3. [VB.NET]Requete INSERT dans base de données access
    Par mael94420 dans le forum ASP.NET
    Réponses: 2
    Dernier message: 05/10/2006, 13h57
  4. Compresser les données avant insertion ?
    Par GregPeck dans le forum Outils
    Réponses: 2
    Dernier message: 07/08/2006, 16h09
  5. [VBA-A] INSERT INTO en vérifiant les données avant !!
    Par Rumeurs dans le forum VBA Access
    Réponses: 9
    Dernier message: 12/04/2006, 14h07

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