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

Requêtes et SQL. Discussion :

Requête INSERT sans effet [AC-2010]


Sujet :

Requêtes et SQL.

  1. #1
    Membre régulier Avatar de scrouet
    Profil pro
    Inscrit en
    Décembre 2003
    Messages
    280
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2003
    Messages : 280
    Points : 105
    Points
    105
    Par défaut Requête INSERT sans effet
    Bonjour.

    Je tente une insertion dans une table de ma base via un code VBA dans l'un des formulaires :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    strRequete = "INSERT INTO NN_Theme_Risque(Rsq_Id, Thm_Id) VALUES (" & lngIdRisque & ", " & lngIdTheme & ");"
    CurrentDb.Execute strRequete
    Debug.Print CurrentDb.RecordsAffected
    Résultat : rien. Pas de nouvelle ligne et pas d'erreur. Le retour de la ligne débug confirme qu'il ne s'est rien passé.
    Que se passe-t-il ?

    La table visée ne contient que ces deux champs, définis conjointement comme clef primaire.

  2. #2
    Membre expérimenté
    Avatar de mumen
    Homme Profil pro
    Développement à façon multisecteur.
    Inscrit en
    Mars 2004
    Messages
    566
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France

    Informations professionnelles :
    Activité : Développement à façon multisecteur.

    Informations forums :
    Inscription : Mars 2004
    Messages : 566
    Points : 1 381
    Points
    1 381
    Par défaut
    Bonjour

    Ajoute dbFailOnError à la commande Execute

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    CurrentDb.Execute strRequete, dbFailOnError
    Ce qui te donnera sans doute l'information (l'erreur) recherchée.

    Ensuite, quand tu utilise CurrentDb, c'est toujours une nouvelle instance de la base de données qui est créée et donc l'instruction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Debug.Print CurrentDb.RecordsAffected
    ne peut que retourner 0. Donc dimensionne une variable comme ici :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    Dim db as database
    set db= CurrentDb
    strRequete = "INSERT INTO NN_Theme_Risque(Rsq_Id, Thm_Id) VALUES (" & lngIdRisque & ", " & lngIdTheme & ");"
    db.Execute strRequete, dbFailOnError
    Debug.Print db.RecordsAffected

  3. #3
    Membre régulier Avatar de scrouet
    Profil pro
    Inscrit en
    Décembre 2003
    Messages
    280
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2003
    Messages : 280
    Points : 105
    Points
    105
    Par défaut
    Merci pour le paramètre optionnel. J'ai pu comprendre que cela ne fonctionnait pas car je tentais d'utiliser l'identifiant Rsq_Id d'un risque en cours de création et non encore enregistré dans sa table.

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

Discussions similaires

  1. [MySQL] insert into sans effet
    Par onda47 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 16/02/2013, 02h26
  2. [PhoneGap][JQueryMobile][JSONP]Requête sans effet
    Par tails dans le forum Android
    Réponses: 4
    Dernier message: 19/11/2010, 12h06
  3. Requête INSERT avec 2 SELECT sans liaison?
    Par kooky dans le forum SQL
    Réponses: 3
    Dernier message: 21/03/2010, 15h57
  4. [SQL Server 2005] BULK INSERT sans effet
    Par mout1234 dans le forum Développement
    Réponses: 5
    Dernier message: 11/02/2009, 09h39
  5. Requête UPDATE sans effet
    Par Death83 dans le forum Requêtes
    Réponses: 4
    Dernier message: 15/01/2006, 01h23

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