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 MySQL Discussion :

Requête insert - demande d'aide


Sujet :

Requêtes MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Futur Membre du Club
    Inscrit en
    Septembre 2009
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Septembre 2009
    Messages : 4
    Par défaut Requête insert - demande d'aide
    Bonjour à tous,
    Je me casse la tête pour essayer de mettre à jour une table par rapport aux enregistrements contenus dans 2 autres tables. Explications :

    Table_1
    MATNR
    110-01-210
    110-02-210
    111-01-210

    Table_2
    MATNR VORNR
    110-xx-210 10
    110-xx-210 20
    110-xx-210 30
    111-xx-210 10
    111-xx-210 20

    Table_3
    struct. idem table 2

    Je cherche à insérer dans table_3 toutes les opérations de table_2 pour chaque record de table_1.
    Exemple pour le record 110-01-210 de table_1, table_3 devra contenir les 3 records suivants:
    110-01-210 10
    110-01-210 20
    110-01-210 30

    Est-ce que quelqu'un a une idée de la requête à effectuer ?
    Un GRAND Merci d'avance pour vos réponses et longue vie à ce
    super forum.
    LR

  2. #2
    Membre Expert
    Avatar de Maljuna Kris
    Homme Profil pro
    Retraité
    Inscrit en
    Novembre 2005
    Messages
    2 613
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 73
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2 613
    Par défaut
    Saluton,
    Ça me semblerais assez basique comme requête, si on avait vraiment la structure des tables

    Peut-être qqe chose comme ça
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    INSERT INTO Table_3
    (SELECT * FROM Table_2 t2
    INNER JOIN Table_1 t1
    ON LEFT(t1.MATNR,4)=LEFT(t2.MATNR,4))
    Kie lumo eksistas ankaŭ ombro troviĝas. L.L. Zamenhof
    articles : Comment émuler un tableau croisé [quasi] dynamique
    et : Une énigme mathématique résolue avec MySQL
    recommande l'utilisation de PDO (PHP5 Data Objects)

  3. #3
    Futur Membre du Club
    Inscrit en
    Septembre 2009
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Septembre 2009
    Messages : 4
    Par défaut Structures des tables
    Structure Table_1
    -----------------
    MATNR varchar(30)
    MAKTX varchar(30)
    LIGNE varchar(20)
    ETABL varchar(20)
    DATE1 date
    TCYCL decimal(2,0)
    USER varchar(20)
    TIME datetime

    110-01-210-41-105101 Art.1
    110-02-210-01-839101 Art.2
    110-01-304-41-001101 Art.3


    Structure Table_2
    -----------------
    MATNR varchar(30)
    VORNR int(11)
    OPERA varchar(30)
    NMACH varchar(30)
    TYPEM varchar(30)
    EMPLA varchar(20)
    NOUTI varchar(20)
    REMA1 mediumtext
    CADEN decimal(4,0)
    TREGL decimal(2,0)
    TMENT decimal(2,0)

    110-xx-210-41-105101 10 OP.1
    110-xx-210-41-105101 20 OP.2
    110-xx-210-41-105101 30 OP.3
    110-xx-210-41-105101 40 OP.4
    110-xx-304-41-001101 10 OP.1
    110-xx-304-41-001101 20 OP.2
    110-xx-304-41-001101 30 OP.3


    Structure Table_3
    -----------------
    idem Table_2
    Pour chaque enregistrement de Table_1, trouver ses correspondants
    "génériques" dans Table_2 et les insérer dans Table_3

    Exemple pour 110-01-210-41-105101 de Table_1 :
    110-xx-210-41-105101 10 OP.1
    110-xx-210-41-105101 20 OP.2
    110-xx-210-41-105101 30 OP.3

    Les 3 enregistrements suivants doivent être insérés dans Table_3
    110-01-210-41-105101 10 OP.1
    110-01-210-41-105101 20 OP.2
    110-01-210-41-105101 30 OP.3
    Merci d'avance pour votre aide et meilleures salutations
    LR

  4. #4
    Membre Expert
    Avatar de Maljuna Kris
    Homme Profil pro
    Retraité
    Inscrit en
    Novembre 2005
    Messages
    2 613
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 73
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2 613
    Par défaut
    Ooops, j'avais la vue un peu courte.
    Ça serait plutôt qqe chose comme ça:
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    INSERT INTO Table_3 t3(t3.MATNR,t3.VORNR,t3.OPERA))
    (SELECT t1.MATNR,t2.VORNR,t2.OPERA
    FROM Table_2 t2
    INNER JOIN Table_1 t1 ON
    CONCAT(LEFT(t1.MATNR,4),SUBSTR(t1.MATNR,8))=
    CONCAT(LEFT(t2.MATNR,4),SUBSTR(t2.MATNR,8)))
    Kie lumo eksistas ankaŭ ombro troviĝas. L.L. Zamenhof
    articles : Comment émuler un tableau croisé [quasi] dynamique
    et : Une énigme mathématique résolue avec MySQL
    recommande l'utilisation de PDO (PHP5 Data Objects)

  5. #5
    Futur Membre du Club
    Inscrit en
    Septembre 2009
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Septembre 2009
    Messages : 4
    Par défaut Error message
    Rebonjour,

    Malheureusement, lorsque j'essaye de lancer la requête, j'ai le message d'erreur suivant :

    #1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 't3
    Problèmes de parenthèses mal placées ou de syntaxe peut-être ?

    Merci d'avance pour vos commentaires...
    Salutations
    LR

  6. #6
    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 : 42
    Localisation : France

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

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

    comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    INSERT INTO Table_3(MATNR,VORNR,OPERA)
    (SELECT t1.MATNR,t2.VORNR,t2.OPERA
    FROM Table_2 t2
    INNER JOIN Table_1 t1 ON
    CONCAT(LEFT(t1.MATNR,4),SUBSTR(t1.MATNR,8))=
    CONCAT(LEFT(t2.MATNR,4),SUBSTR(t2.MATNR,8)))

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

Discussions similaires

  1. Besoin aide pour requète insert
    Par jibileg dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 04/09/2008, 19h31
  2. [WD12] Demande d'aide pour concevoir ma requête
    Par tom06440 dans le forum WinDev
    Réponses: 9
    Dernier message: 01/06/2008, 16h46
  3. Demande d'aide pour l'optimisation d'une requête
    Par Menoto dans le forum Optimisations
    Réponses: 4
    Dernier message: 04/04/2008, 12h36
  4. Réponses: 2
    Dernier message: 02/03/2006, 11h57
  5. Demande d'aide pour une requête
    Par arkzor dans le forum Requêtes
    Réponses: 3
    Dernier message: 28/12/2004, 02h40

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