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 :

Modification d'une procédure


Sujet :

SQL Procédural MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Juillet 2012
    Messages
    93
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Juillet 2012
    Messages : 93
    Par défaut Modification d'une procédure
    bonjour, j'ai une procédure qui me permet de récupérer des données depuis une table "import" pour les intégrer dans ma base de données.
    Aujourd'hui on m'a apporté des fichiers complémentaires pour cette base de données.
    Une fois remontés dans la table import j'ai voulu lancé la procédure et ça n'a pas marché et ça m'affiche le message d'erreur suivant "#1062 - Duplicate entry '547671-13-0' for key 'PRIMARY'".

    Il faudrait donc que je rajoute dans ma procédure que si l'entrée existe déjà on l'écrase.

    ma procédure est la suivante
    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
    DELIMITER |
     
    DROP PROCEDURE IF EXISTS import_donnees|
    CREATE PROCEDURE import_donnees( nbCapteur INTEGER)
     
    BEGIN
     
    DECLARE iter INTEGER DEFAULT 0; 
     
    iterwhile: WHILE iter <= nbCapteur DO 
     
      SET @myInsert:= CONCAT('
    INSERT INTO relever_mesure(valeur, id_calendrier_calendrier, id_station_Stations, id_capteur_capteur)
    SELECT i.`',iter,'`,
           c.id_calendrier,
           i.id_station,
           ',iter,' 
    FROM import i
    INNER JOIN calendrier c ON i.date_heure = c.date_heure_locale
    WHERE i.`',iter,'` <>"(null)"');
     
     
      prepare stmnt FROM @myInsert; 
      EXECUTE stmnt; 
      DEALLOCATE PREPARE stmnt;
     
     
       SET iter = iter + 1; 
    END WHILE iterwhile;
    END |
    je essayer avec ON DUPLICATE KEY UPDATE IF EXIST

    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
    DELIMITER |
     
    DROP PROCEDURE IF EXISTS import_donnees|
    CREATE PROCEDURE import_donnees( nbCapteur INTEGER)
     
    BEGIN
     
    DECLARE iter INTEGER DEFAULT 0; 
     
    iterwhile: WHILE iter <= nbCapteur DO 
     
      SET @myInsert:= CONCAT('
    INSERT INTO relever_mesure(valeur, id_calendrier_calendrier, id_station_Stations, id_capteur_capteur)
    SELECT i.`',iter,'`,
           c.id_calendrier,
           i.id_station,
           ',iter,' 
    FROM import i
    INNER JOIN calendrier c ON i.date_heure = c.date_heure_locale
    WHERE i.`',iter,'` <>"(null)"')
    ON DUPLICATE KEY UPDATE i.date_heure=c.date_heure_locale
                                    AND i.id_capteur=r.id_station_Stations;
     
     
      prepare stmnt FROM @myInsert; 
      EXECUTE stmnt; 
      DEALLOCATE PREPARE stmnt;
     
     
       SET iter = iter + 1; 
    END WHILE iterwhile;
    END |
    mais ça ne marche pas, alors que sur une ligne ça marche nickel si vous pouvez me dire ou je fait l'erreur merci

  2. #2
    Expert éminent
    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 814
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 814
    Billets dans le blog
    14
    Par défaut
    Pourquoi IF EXISTS ? C'est un pléonasme avec ON DUPLICATE KEY !
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole, en retraite... mais toujours Autoentrepreneur à l'occasion.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

  3. #3
    Membre confirmé
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Juillet 2012
    Messages
    93
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Juillet 2012
    Messages : 93
    Par défaut
    Pourquoi IF EXISTS ? C'est un pléonasme avec ON DUPLICATE KEY !
    Vi j'etais en train de modifier quand tu es passé, j'ai compris l'erreur j'ai essayer avec

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ON DUPLICATE KEY UPDATE i.date_heure=c.date_heure_locale
                                    AND i.id_station=r.id_station_Stations;
    mais pareil ça ne marche pas quand même

  4. #4
    Expert éminent
    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 814
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 814
    Billets dans le blog
    14
    Par défaut
    Regarde le dernier exemple donnée dans la doc MySQL :
    Citation Envoyé par MySQL
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    INSERT INTO table (a,b,c) VALUES (1,2,3)
      ON DUPLICATE KEY UPDATE id=LAST_INSERT_ID(id), c=3;
    Il faut une virgule entre les instructions de mise à jour, comme dans une requête UPDATE.

    AND est un opérateur booléen. Il ne signifie pas "ET" au sens grammatical.
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole, en retraite... mais toujours Autoentrepreneur à l'occasion.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

  5. #5
    Membre confirmé
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Juillet 2012
    Messages
    93
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Juillet 2012
    Messages : 93
    Par défaut
    ok,

    Ce que je ne comprend pas c'est que je voudrais qu'on remplace les lignes existantes quand l'id_station, id_date_heure et l'id_capteur sont les mêmes
    donc
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ON DUPLICATE KEY UPDATE i.date_heure=c.date_heure_locale, i.id_station=r.id_station_Stations, id_capteur_capteur=id_capteur_capteur;
    mais ça ne marche pas ça me dit que j'ai une erreur de syntax

  6. #6
    Expert éminent
    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 814
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 814
    Billets dans le blog
    14
    Par défaut
    Redonne ton code complet.
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole, en retraite... mais toujours Autoentrepreneur à l'occasion.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 05/05/2014, 15h36
  2. Réponses: 8
    Dernier message: 10/04/2014, 16h28
  3. Modification du jeu de résultats d'une procédure stockée
    Par chris2010 dans le forum Développement
    Réponses: 7
    Dernier message: 21/12/2010, 15h09
  4. passage d'un nom de table dans une procédure stockée
    Par thierry V dans le forum MS SQL Server
    Réponses: 7
    Dernier message: 26/07/2010, 16h48
  5. Réponses: 5
    Dernier message: 18/06/2007, 18h00

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