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

Langage SQL Discussion :

INSERT et SELECT avec clé étrangère


Sujet :

Langage SQL

  1. #1
    Futur Membre du Club
    Homme Profil pro
    élève ingénieur des travaux informatiques
    Inscrit en
    Mars 2014
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : élève ingénieur des travaux informatiques

    Informations forums :
    Inscription : Mars 2014
    Messages : 12
    Points : 9
    Points
    9
    Par défaut INSERT et SELECT avec clé étrangère
    bonjour à tous j'ai un problème
    j'ai essayé mais je n'enregistre rien
    NB: j'ai mis les champ Id de mes tables en cascade
    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
     natCourrier=ui->comboBoxNature->currentText();
        ObjCourrier=ui->lineEditObjet->text();
        natureRep=ui->comboBoxReponse->currentText();
        Attente=ui->comboBoxAttente->currentText();
                                    QSqlQuery qCourrier;
                                    qCourrier.prepare("INSERT INTO courrier(IdNature,DateCourrier,DateEnregistrement,DelaiDeReponse,Objet,Contenu,AttenteReponse,NatureReponse) VALUES ((SELECT IdNature FROM naturecourrier WHERE LibCourrier='"+natCourrier+"'),:dateCourrier,:dateEnregistrement,:datePeremtion,'"+ObjCourrier+"','"+contenu+"','"+Attente+"','"+natureRep+"')");
                                    qCourrier.bindValue("dateCourrier",ui->dateEditDateCourrier->date());
                                    qCourrier.bindValue("dateEnregistrement",ui->dateEditEnregistrement->date());
                                    qCourrier.bindValue("datePeremtion",ui->dateEditDateLimite->date());
                                        if(!qCourrier.exec()){
     
                                            QMessageBox::critical(this, tr("error::"),qCourrier.lastError().text());
     
                                            }
                                        else{
                                               QMessageBox::information(this,tr("Enregistrement"),tr("Courrier enregistré"));
                                            }
    }

  2. #2
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 088
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 088
    Points : 38 393
    Points
    38 393
    Billets dans le blog
    9
    Par défaut
    A minima vous devriez indiquer votre SGBD, sa version et le message obtenu en retour de votre requête.

    Avez vous vérifié que votre requete select servant à récupérer la valeur de l'id vous ramène quelque chose ?

  3. #3
    Futur Membre du Club
    Homme Profil pro
    élève ingénieur des travaux informatiques
    Inscrit en
    Mars 2014
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : élève ingénieur des travaux informatiques

    Informations forums :
    Inscription : Mars 2014
    Messages : 12
    Points : 9
    Points
    9
    Par défaut
    j'utilise MySql sous wampserver et j ai essayé de vérifier sa ne me renvoi rien j'ai cru que la requette est mauvaise

  4. #4
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 088
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 088
    Points : 38 393
    Points
    38 393
    Billets dans le blog
    9
    Par défaut
    Arrivez vous à vous connecter à la base de données ?

    Non : consultez la FAQ MySQL ici : http://mysql.developpez.com/faq/

    Oui : exécutez votre sous-requete select seule, et vérifiez son résultat

  5. #5
    Membre expert
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Octobre 2013
    Messages
    1 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2013
    Messages : 1 563
    Points : 3 404
    Points
    3 404
    Par défaut
    Citation Envoyé par micheliai Voir le message
    j'utilise MySql sous wampserver et j ai essayé de vérifier sa ne me renvoi rien j'ai cru que la requette est mauvaise
    Faudrait essayer d'exécuter la requête hors de l'application (MySQLWorkbench par exemple).

  6. #6
    Futur Membre du Club
    Homme Profil pro
    élève ingénieur des travaux informatiques
    Inscrit en
    Mars 2014
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : élève ingénieur des travaux informatiques

    Informations forums :
    Inscription : Mars 2014
    Messages : 12
    Points : 9
    Points
    9
    Par défaut
    Bonsoir à tous,
    Je vais essayer d'expliquer mon problème d'une meilleure manière parce que ce que vous essayez de résoudre fonctionne bien :
    j'ai envie de remplir les Id qui sont des clés étrangères dans les tables de ma base de données et les id qui ont migré dans les tables d'associations.
    Comme je n'ai pas pu faire ça automatiquement par enregistrement, je souhaite faire un select Id from et faire un Insert into pour insérer l'id. C'est pourquoi en fait je me demande s'il est possible de récupérer le résultat d'un QSqlQuery et le stocker dans une variable.
    Sinon comment insérer le résultat d'un select ailleurs ?
    Merci pour votre compréhension

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

Discussions similaires

  1. INSERT et SELECT avec clé étrangère
    Par anisj1m dans le forum Langage SQL
    Réponses: 3
    Dernier message: 28/05/2017, 08h58
  2. MySQL : insertion dans table avec clés étrangères
    Par chatmi dans le forum Requêtes
    Réponses: 7
    Dernier message: 22/06/2012, 16h36
  3. INSERT à partir d'un SELECT avec champ SERIAL
    Par bruno.wiesen dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 21/03/2007, 12h07
  4. Insert select avec BD distante
    Par romuald07 dans le forum Requêtes
    Réponses: 5
    Dernier message: 22/11/2006, 12h10
  5. insertion dans table avec plusieurs clés étrangères
    Par philippe281281 dans le forum Administration
    Réponses: 2
    Dernier message: 14/06/2006, 19h35

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