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 :

Un SELECT dans un UPDATE à la place d'une TABLE ?


Sujet :

Langage SQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2019
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2019
    Messages : 6
    Par défaut Un SELECT dans un UPDATE à la place d'une TABLE ?
    Bonjour,

    Tout est dit dans le titre, j'essaie d'explorer le champ des possible.

    Dans un update basique style :

    UPDATE TABLE
    SET ....
    WHERE ....

    Je me demandais si la table appelée pouvait au final être une selection (select)

    Du style :

    UPDATE (SELECT)
    SET .....



    Est-ce que le select pourrait remplacer le where ?

    Merci beaucoup : Ça m'intrigue énormemennt

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    22 010
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 22 010
    Billets dans le blog
    6
    Par défaut
    Une des syntaxes possibles, mais non normalisées est la suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    UPDATE MonAlias
    SETFROM MaTable AS MonALias
         JOIN UneAutreTable ASON ...
    C'est utilisé notamment par SQL Server, mais n'est pas conforme à la norme SQL (mais c'est tellement pratique, car il suffit de savoir faire des SELECT pour passer à l'UPDATE !)
    https://docs.microsoft.com/en-us/sql...er-2017#upsert

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  3. #3
    Expert confirmé
    Avatar de StringBuilder
    Homme Profil pro
    Chef de projets
    Inscrit en
    Février 2010
    Messages
    4 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2010
    Messages : 4 197
    Billets dans le blog
    1
    Par défaut
    Une alternative, pour les autres SGBD, c'est de créer une vue qui correspond à ton SELECT.
    Et tu peux faire un UPDATE sur la vue.

    Selon la complexité de la requête et les colonnes que tu souhaites mettre à jour, par contre, il faudra peut-être créer des triggers pour lui dire ce qu'il faut faire...

    Par exemple :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    create view vue_commande (id, nb_produits)
    as
    select c.id, count(l.*)
    from commande c
    inner join ligne l on l.c_id = c.id;
     
    update vue_commande set nb_produits = 2 where id = 7;
    => A ce moment il faut lui expliquer quoi faire : ignorer la mise à jour, supprimer des lignes de commandes, ou au contraire en rajouter.

  4. #4
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 636
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 636
    Billets dans le blog
    10
    Par défaut
    Il me semble que la syntaxe suivante fonctionne pour tous les SGBD-R

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    UPDATE TABLE1 T1
    SET (T1.Col1, T1.Col2, ..., T1.Coln) 
      = (SELECT T2.Cola, T2.Colb, ..., T2.Colx
         FROM TABLE2 T2
         WHERE ...)

  5. #5
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    22 010
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 22 010
    Billets dans le blog
    6
    Par défaut
    Non pour très peu… Et les conditions de cette syntaxe sont draconiennes :
    pas de distinct, pas de calcul d'agrégation, pas de transformation des colonnes et un ensemble de valeurs dans le SELECT qui soit sans doublon….

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

Discussions similaires

  1. [HF19] Select dans un update
    Par niuniuk36 dans le forum HyperFileSQL
    Réponses: 4
    Dernier message: 13/01/2016, 16h39
  2. utilisation d'un select dans un update ou insert.
    Par Rafter dans le forum Développement
    Réponses: 6
    Dernier message: 21/07/2014, 13h28
  3. [MySQL] Select dans un Update
    Par Nympheasi dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 31/07/2009, 00h55
  4. [MySQL] un select dans un update
    Par Yoshio dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 18/09/2006, 19h07
  5. [select dans case] reconnaitre un champ d une table liée
    Par the_edge dans le forum MS SQL Server
    Réponses: 14
    Dernier message: 22/10/2004, 16h47

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