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 :

UPDATE avec SUBQUERY


Sujet :

Requêtes MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre très actif
    Inscrit en
    Juin 2005
    Messages
    210
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 210
    Par défaut UPDATE avec SUBQUERY
    Bonjour à tous !

    Je galère pour faire un update massif sur un champ d'une table.

    Alors j'ai 2 tables, T_HALL qui correspond donc à des salles et T_CITY qui correspond donc à des villes de rattachement.

    Dans T_HALL j'ai un champ city_id (celui que je veux updaté car il est null à l'heure actuelle) qui correspond à l'id de la ville de rattachement (T_CITY)
    j'ai également un champ T_HALL.city qui correspond au nom de la ville.

    Dans T_CITY, J'ai un champ id et champ name qui correspond au nom de la ville.

    L'idée est donc d'updater le champ T_HALL.city_id pour chacune des salles où je trouve l'id dans la table des villes de rattachement en se basant sur les noms, et ceci pour dégrossir car j'ai évidemment des cas particuliers comme les villes ayant des arrondissements...
    J'ai fait une table de villes de rattachement pour me simplifier la vie avec les différents codes postaux et noms de villes qui peuvent être multiples (cas des arrondissements par exemple et il peux également y avoir plusieurs codes postaux pour une même ville ou plusieurs villes avec le même code postal) ...

    Donc voici ce que j'ai essayé sans succès :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    UPDATE T_HALL
    SET T_HALL.city_id = (SELECT T_CITY.id FROM T_CITY WHERE T_CITY.name = T_HALL.city)
    WHERE EXISTS (SELECT T_CITY.id FROM T_CITY WHERE T_CITY.name = T_HALL.city);
    ça me renvoie :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Subquery returns more than 1 row
    J'aurais donc besoin de vous pour comprendre ce qui cloche car je suis loin d'être expert sql.

    Merci d'avance.

  2. #2
    Membre Expert Avatar de Yanika_bzh
    Homme Profil pro
    Responsable Applicatif et R&D
    Inscrit en
    Février 2006
    Messages
    1 144
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Responsable Applicatif et R&D
    Secteur : Finance

    Informations forums :
    Inscription : Février 2006
    Messages : 1 144
    Par défaut
    L'erreur est très explicite

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT T_CITY.id FROM T_CITY WHERE T_CITY.name = T_HALL.city
    Vous ramène plus d'une 1 ligne de résultat, donc impossible de faire l'update.
    Il doit donc exister des doublons de nom dans votre table T_CITY.

  3. #3
    Membre très actif
    Inscrit en
    Juin 2005
    Messages
    210
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 210
    Par défaut
    exact il y a des doublons vu qu'il y a plusieurs villes qui ont le même nom ...
    J'avais pas pensé à ça ! merci
    je vais donc utiliser le Code Postal mais bon du coup ça va beaucoup plus filtrer avec cette histoire des multiples codes postaux ...
    Bon tant pis...

  4. #4
    Membre très actif
    Inscrit en
    Juin 2005
    Messages
    210
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 210
    Par défaut
    Et sinon sais tu comment faire une requête pour identifier ces doublons ?

  5. #5
    Membre Expert Avatar de Yanika_bzh
    Homme Profil pro
    Responsable Applicatif et R&D
    Inscrit en
    Février 2006
    Messages
    1 144
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Responsable Applicatif et R&D
    Secteur : Finance

    Informations forums :
    Inscription : Février 2006
    Messages : 1 144
    Par défaut
    Genre ceci ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT 
        name 
    FROM
        T_CITY 
    GROUP BY
      name
    HAVING COUNT (1)>1

  6. #6
    Membre très actif
    Inscrit en
    Juin 2005
    Messages
    210
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 210
    Par défaut
    Merci bien

    Bon sinon j'ai une autre question, j'ai tenté autre chose mais je bloque !

    En fait j'ai fait ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    UPDATE T_HALL
    SET T_HALL.city_id = (SELECT T_CITY.id FROM T_CITY WHERE name = 'albi')
    WHERE city like 'albi';
    Mais j'aimerais bien appliquer ceci à toute une liste de noms de ville, retournée par cette requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT city FROM T_HALL WHERE city_id IS NULL GROUP BY city ORDER BY city;
    En gros il faudrait remplacer le "albi" de ma requête test pour que ça l'applique sur toute la liste retournée par cette 2ème requête.

    Est-ce que c'est possible juste par SQL ?

    Merci d'avance

Discussions similaires

  1. UPDATE avec JOIN ?
    Par zakuli dans le forum Débuter
    Réponses: 3
    Dernier message: 25/07/2007, 14h53
  2. UPDATE avec des variables Delphi ...
    Par Kokito dans le forum Bases de données
    Réponses: 3
    Dernier message: 08/03/2004, 22h35
  3. Requete d'update avec concatenation !!
    Par chris92 dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 25/02/2004, 12h05
  4. [version] Requete Update avec différentes versions de mySQL
    Par regbegpower dans le forum Requêtes
    Réponses: 2
    Dernier message: 26/01/2004, 17h19
  5. Pb Update avec chaine de caractere
    Par JuJu° dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 28/05/2003, 15h58

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