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 avec requête imbriquée


Sujet :

Langage SQL

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Février 2008
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 6
    Points : 5
    Points
    5
    Par défaut Insert avec requête imbriquée
    Bonjour,

    J'aimerais créer un Insert avec une requête imbriquée et en rajoutant également des champs. Heu... c'es pas clair alors je vais plutôt vous mettre ma requête

    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
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
     
    INSERT INTO GP3U00.BTARIF
    	(BPRO_EAN, 
    	 BPRO_CINT, 
    	 BTAR_CENT, 
    	 BTAR_CENTB, 
    	 BTAR_CTAR, 
    	 BTAR_PV01, 
    	 BTAR_PVMO, 
    	 BTAR_DAT2, 
    	 BTAR_DAT3, 
    	 BTAR_QUTE, 
    	 BTAR_TAX1, 
    	 BTAR_TAX2, 
    	 BTAR_TVAL, 
    	 BTAR_PVA1, 
    	 BTAR_PVMA, 
    	 BTAR_CGRP, 
    	 BTAR_REGI, 
    	 BTAR_ECOT)
    VALUES (
    	(SELECT BPXACH.BPRO_EAN, BPXACH.BPRO_CINT, BPXACH.BPXA_CENT, BPXACH.BPXA_CENT
    		FROM GP3U00.BPRODT, GP3U00.BPXACH
    		WHERE BPRODT.BPRO_CINT = BPXACH.BPRO_CINT
    		AND BPRODT.BPRO_EAN = BPXACH.BPRO_EAN
    		AND NOT EXISTS (
    			SELECT BTARIFSRC.BPRO_EAN, BTARIFSRC.BPRO_CINT, BTARIFSRC.BTAR_CENT, BTARIFSRC.BTAR_CENT
    			FROM GP3U00.BPRODT BPRODTSRC, GP3U00.BTARIF BTARIFSRC
    			WHERE BPRODTSRC.BPRO_EAN = BTARIFSRC.BPRO_EAN
    			AND BPRODTSRC.BPRO_CINT = BTARIFSRC.BPRO_CINT
    			AND BPRODT.BPRO_EAN = BPRODTSRC.BPRO_EAN
    			AND BPRODT.BPRO_CINT = BPRODTSRC.BPRO_CINT
    			AND BPXACH.BPXA_CENT = BTARIFSRC.BTAR_CENT
    			GROUP BY BPRODTSRC.BPRO_EAN, BPRODTSRC.BPRO_CINT
    		)
    	), 'T3', 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 'GROUP', 0, 0)
    Ca fait trois heures que je cherche en vain. C'est une base Oracle 10g mais il faudrait aussi que la requête soit compatible sur MySQL.

    En vous remerciant par avance,

    Kyra

  2. #2
    Membre émérite

    Profil pro
    Inscrit en
    Mars 2005
    Messages
    1 683
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Mars 2005
    Messages : 1 683
    Points : 2 579
    Points
    2 579
    Par défaut
    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
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    INSERT INTO GP3U00.BTARIF
    	(BPRO_EAN, 
    	 BPRO_CINT, 
    	 BTAR_CENT, 
    	 BTAR_CENTB, 
    	 BTAR_CTAR, 
    	 BTAR_PV01, 
    	 BTAR_PVMO, 
    	 BTAR_DAT2, 
    	 BTAR_DAT3, 
    	 BTAR_QUTE, 
    	 BTAR_TAX1, 
    	 BTAR_TAX2, 
    	 BTAR_TVAL, 
    	 BTAR_PVA1, 
    	 BTAR_PVMA, 
    	 BTAR_CGRP, 
    	 BTAR_REGI, 
    	 BTAR_ECOT)
    VALUES (
    	(SELECT BPXACH.BPRO_EAN, BPXACH.BPRO_CINT, BPXACH.BPXA_CENT, BPXACH.BPXA_CENT, 'T3', 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 'GROUP', 0, 0
    		FROM GP3U00.BPRODT, GP3U00.BPXACH
    		WHERE BPRODT.BPRO_CINT = BPXACH.BPRO_CINT
    		AND BPRODT.BPRO_EAN = BPXACH.BPRO_EAN
    		AND NOT EXISTS (
    			SELECT BTARIFSRC.BPRO_EAN, BTARIFSRC.BPRO_CINT, BTARIFSRC.BTAR_CENT, BTARIFSRC.BTAR_CENT
    			FROM GP3U00.BPRODT BPRODTSRC, GP3U00.BTARIF BTARIFSRC
    			WHERE BPRODTSRC.BPRO_EAN = BTARIFSRC.BPRO_EAN
    			AND BPRODTSRC.BPRO_CINT = BTARIFSRC.BPRO_CINT
    			AND BPRODT.BPRO_EAN = BPRODTSRC.BPRO_EAN
    			AND BPRODT.BPRO_CINT = BPRODTSRC.BPRO_CINT
    			AND BPXACH.BPXA_CENT = BTARIFSRC.BTAR_CENT
    			GROUP BY BPRODTSRC.BPRO_EAN, BPRODTSRC.BPRO_CINT
    		)
    	) )

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Février 2008
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 6
    Points : 5
    Points
    5
    Par défaut
    Je viens d'essayer cette requête sous Oracle SQL*Plus et voilà le message qu'il me retourne

    ERROR at line 20:
    ORA-00947: not enough values

  4. #4
    Membre émérite

    Profil pro
    Inscrit en
    Mars 2005
    Messages
    1 683
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Mars 2005
    Messages : 1 683
    Points : 2 579
    Points
    2 579
    Par défaut
    Merci de ne pas copier coller les messages d'erreur et de faire une recherche google avant. Vous êtes parfaitement en mesure de comprendre une erreur aussi triviale.

  5. #5
    Futur Membre du Club
    Profil pro
    Inscrit en
    Février 2008
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 6
    Points : 5
    Points
    5
    Par défaut
    Je pense que c'est juste qu'il manque des valeurs dans ma clause NOT EXISTS.
    Le soucis c'est que j'aimerais juste comparer les valeurs que j'avais mis dans mon SELECT et du coup je ne vois pas trop comment faire.

  6. #6
    Membre émérite

    Profil pro
    Inscrit en
    Mars 2005
    Messages
    1 683
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Mars 2005
    Messages : 1 683
    Points : 2 579
    Points
    2 579
    Par défaut
    google > ORA-00947: not enough values

    1ere page de résultat :

    Another common cause of this error is an INSERT statement in which the VALUES or SELECT clause does not contain enough values needed for the INSERT, as in

    INSERT INTO EMP(EMPNO,ENAME) VALUES('JONES')
    Toujours pas ?

  7. #7
    Futur Membre du Club
    Profil pro
    Inscrit en
    Février 2008
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 6
    Points : 5
    Points
    5
    Par défaut
    Problème résolu. Voici la requête définitive pour information :

    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
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
     
    INSERT INTO GP3U00.BTARIF
    	(BPRO_EAN, 
    	 BPRO_CINT, 
    	 BTAR_CENT, 
    	 BTAR_CENTB, 
    	 BTAR_CTAR, 
    	 BTAR_PV01, 
    	 BTAR_PVMO, 
    	 BTAR_DAT2, 
    	 BTAR_DAT3, 
    	 BTAR_QUTE, 
    	 BTAR_TAX1, 
    	 BTAR_TAX2, 
    	 BTAR_TVAL, 
    	 BTAR_PVA1, 
    	 BTAR_PVMA, 
    	 BTAR_CGRP, 
    	 BTAR_REGI, 
    	 BTAR_ECOT)
    	SELECT BPXACH.BPRO_EAN, BPXACH.BPRO_CINT, BPXACH.BPXA_CENT, BPXACH.BPXA_CENT, 'T3', 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 'GROUP', 0, 0
    		FROM GP3U00.BPRODT, GP3U00.BPXACH
    		WHERE BPRODT.BPRO_CINT = BPXACH.BPRO_CINT
    		AND BPRODT.BPRO_EAN = BPXACH.BPRO_EAN
    		AND NOT EXISTS (
    			SELECT *
    			FROM GP3U00.BPRODT BPRODTSRC, GP3U00.BTARIF BTARIFSRC
    			WHERE BPRODTSRC.BPRO_EAN = BTARIFSRC.BPRO_EAN
    			AND BPRODTSRC.BPRO_CINT = BTARIFSRC.BPRO_CINT
    			AND BPRODT.BPRO_EAN = BPRODTSRC.BPRO_EAN
    			AND BPRODT.BPRO_CINT = BPRODTSRC.BPRO_CINT
    			AND BPXACH.BPXA_CENT = BTARIFSRC.BTAR_CENT
    			GROUP BY BPRODTSRC.BPRO_EAN, BPRODTSRC.BPRO_CINT)
    Merci vmolines pour tes renseignements.

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

Discussions similaires

  1. Requête Update avec requête imbriquée
    Par sybaris dans le forum Développement
    Réponses: 2
    Dernier message: 05/07/2008, 12h51
  2. [MySQL] formulaire insertion avec requête
    Par wail00 dans le forum PHP & Base de données
    Réponses: 15
    Dernier message: 14/05/2007, 15h04
  3. Delete avec requête imbriquée et clé primaire
    Par boutss dans le forum Oracle
    Réponses: 4
    Dernier message: 12/03/2007, 15h32
  4. insertion avec requête imbriquées
    Par Manfried dans le forum Requêtes
    Réponses: 7
    Dernier message: 19/11/2005, 09h51
  5. Réponses: 4
    Dernier message: 04/08/2005, 08h23

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