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

SQL Procédural MySQL Discussion :

Des Insert dans une table à partir de données contenues dans une autre


Sujet :

SQL Procédural MySQL

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    124
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2006
    Messages : 124
    Points : 87
    Points
    87
    Par défaut Des Insert dans une table à partir de données contenues dans une autre
    Bonjour à tous,

    Je dois insérer des données dans une table en me basant sur une sélection et des données contenues dans une autre.

    Disons par ex. que j'ai une table Personnes:

    et je dois abonner en 2008 à une revue tous les habitants d'une commune. Je dois donc insérer dans la table Abonnements des données de la forme

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    id personne_id  annee_abonnement
    où id est auto-incrémenté.

    Je dois donc faire une opération du genre

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Pour chaque personne WHERE commune LIKE machin:
     
    INSERT INTO abonnements (personne_id, annee_abonnement) VALUES (personne_id, '2008')
    Comment réaliser ce genre de chose ?

    Merci d'avance

  2. #2
    Expert confirmé Avatar de Cybher
    Homme Profil pro
    Consultant réseaux et sécurité
    Inscrit en
    Mai 2005
    Messages
    3 281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Consultant réseaux et sécurité
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 281
    Points : 4 641
    Points
    4 641
    Par défaut
    salut,


    quelque chose dans ce style
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    INSERT INTO abonnements  select personne_id, '2008' from personnes where commune like ..
    A+

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    124
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2006
    Messages : 124
    Points : 87
    Points
    87
    Par défaut
    Merci,

    La solution était précisément

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    INSERT INTO abonnements  select NULL,personne_id, '2008' from personnes where commune like ..
    parce que le nombre de colonnes insérées doit être égal à celui présent dans la talble. Le fait d'insérer un NULL permet au champs auto-incrémenté de faire, eh bien ce qu'il a à faire, s'incrémenter

    (Je ne l'ai pas trouvé tout seul, j'ai regardé le code SQL de la même opération effectuée avec PhpMyAdmin)

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

Discussions similaires

  1. [AC-2003] Créer une table à partir de la structure d'une table existante
    Par ted the Ors dans le forum VBA Access
    Réponses: 10
    Dernier message: 26/01/2010, 15h33
  2. Réponses: 2
    Dernier message: 27/04/2009, 16h32
  3. [MySQL] Insérer des données dans une table, mais ce n'est pas une table USER
    Par amerex dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 16/08/2008, 00h01
  4. Réponses: 1
    Dernier message: 28/04/2008, 16h47
  5. Réponses: 7
    Dernier message: 16/01/2007, 15h54

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