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 :

la requête INSERT INTO. . . SELECT


Sujet :

Langage SQL

  1. #1
    Membre du Club
    Inscrit en
    Août 2007
    Messages
    60
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 60
    Points : 40
    Points
    40
    Par défaut la requête INSERT INTO. . . SELECT
    bonjour à tous
    je veux procéder à l insertion d enregistrements dans une table qu on nommera tabl_tempo via la requête INSERT INTO. le hic est que le contenu des différentes colonnes n est autre que le résultat de plusieurs requêtes, donc j ai pensé à INSERT INTO ..... SELECT.le problème est que le contenu de chaque colonne est le résultat d une requête à part. donc j arrive à trouver le moyen de rassembler toutes les requêtes en une seule ligne. merci d avance pour vos suggestions

  2. #2
    Membre chevronné Avatar de philnext
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    1 552
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 1 552
    Points : 1 780
    Points
    1 780
    Par défaut
    euh tu peux donner un exemple de ce que tu veux faire ??

  3. #3
    Membre du Club
    Inscrit en
    Août 2007
    Messages
    60
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 60
    Points : 40
    Points
    40
    Par défaut
    Bonsoir
    Bon j'explique un peu plus.J'ai une table appelée par exemple bd_essai.mdb. J'ai deux colonnes: une colonne ID et une autre nommée ACTION.Pour un seul ID il peut y avoir différentes ACTION('pass','fail'). Donc, ce que je veux faire c'est créer une autre table qui comportera l'ID, le nombre total des ACTION qu'il a, et pour chaque ACTION son nombre d'occurence. Pour ce faire, il me faut une requête pour sélectionner les ID, une autre pour calculer toutes les ACTION, une autre pour chaque ACTION pour calculer le nombre d'occurence. Pour les requêtes de point de vue syntaxe ça va, mais le problème est que je veux les placer comme arguments de la requête INSERT INTO.merci d'avance

  4. #4
    Membre averti Avatar de AL1986
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    434
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 434
    Points : 441
    Points
    441
    Par défaut
    Quel SGBD utilises-tu ? et comment communiques-tu avec la BD (language de prog) ?
    Etre ou ne pas être, telle est la question sinusoïdale de l'anachorète hypocondriaque et vice et versa .
    Bonsai monsieur, bonsai madame, vous avez gagnez un milliard de degrés au soleil .
    There is no cure for stupidity (ou pas ).

  5. #5
    Membre habitué
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2006
    Messages
    80
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Mayenne (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2006
    Messages : 80
    Points : 197
    Points
    197
    Par défaut
    Citation Envoyé par asma_tn Voir le message
    l'ID, le nombre total des ACTION qu'il a, et pour chaque ACTION son nombre d'occurence.
    ça doit pourvoir se faire en une seule requète, non ?

    genre si tu as un requète qui te ramène les résultats suivants :
    1 fail 24
    1 pass 5
    2 fail 12
    2 pass 36
    3 fail 7
    3 pass 4

    Ca te conviendrait ?


    cf. discussion http://www.developpez.net/forums/sho...d.php?t=408054 (modulo un COUNT à rajouter en fin de SELECT...)
    "Always code as if the person who ends up maintaining your code is a violent psychopath who knows where you live." (Code for the Maintainer)
    I usually maintain my own code, so the as-if is true!

  6. #6
    Membre du Club
    Inscrit en
    Août 2007
    Messages
    60
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 60
    Points : 40
    Points
    40
    Par défaut
    Citation Envoyé par Pergos Voir le message
    ça doit pourvoir se faire en une seule requète, non ?

    genre si tu as un requète qui te ramène les résultats suivants :
    1 fail 24
    1 pass 5
    2 fail 12
    2 pass 36
    3 fail 7
    3 pass 4

    Ca te conviendrait ?


    cf. discussion http://www.developpez.net/forums/sho...d.php?t=408054 (modulo un COUNT à rajouter en fin de SELECT...)
    salut à vous

    merci pour le coup de main et je m excuse pour le retard!concernant ta reflexion Pergos je n ai pas pu le faire en une seule requête donc j ai du travailler sur 2tables temporaires (vue que je travaille sous VB). le problème est que la clause where diffère!

    pour la première
    insert into tabl_temporaire select id, count(action) as nb_pass where action = 'pass' group by id;
    insert into tabl_temporaire select id,count(action) as nb_fail where action='fail' group by id

    pour la deuxième il suffit de regrouper les id

    insert into tabl_temporaire_2 select SFC,Sum(nb_fail),sum(nb_pass)from tabl_temporaire where 1 group by id

    c est surement pas très esthétique, mais c est la seule solution que j ai trouvé! ( vu que je ne suis pas très expérimentée en sql)

    A+
    Asma

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

Discussions similaires

  1. [AC-2002] Requête INSERT INTO avec SELECT et VALUES
    Par chim33 dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 10/03/2010, 16h45
  2. Requête INSERT INTO SELECT
    Par unix27 dans le forum Langage SQL
    Réponses: 5
    Dernier message: 11/02/2007, 00h36
  3. probleme dans un INSERT INTO...........SELECT
    Par briiice dans le forum Requêtes
    Réponses: 5
    Dernier message: 26/01/2006, 15h13
  4. Incrémenter champ : insert into . select max(.) + 1 from .
    Par ludo.guy dans le forum Langage SQL
    Réponses: 10
    Dernier message: 25/11/2004, 14h39
  5. Erreur lors d'une requete insert into.. select
    Par Mr N. dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 04/11/2004, 17h32

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