web-dev-qa-db-fra.com

Mise à jour SQL - plusieurs colonnes

Je voudrais mettre à jour plusieurs colonnes dans une table en fonction des valeurs d'une deuxième table en utilisant une instruction Select pour obtenir les valeurs comme ceci:

UPDATE tbl1 
SET (col1, col2, col3) = (SELECT colA, colB, colC 
                          FROM tbl2 
                          WHERE tbl2.id = 'someid') 
WHERE tbl1.id = 'differentid'

Cependant, il ne semble pas possible de "définir" plus d'un nom de colonne - existe-t-il des alternatives plutôt que d'écrire des instructions de mise à jour distinctes pour chaque colonne?

UPDATE tbl1 
SET col1 = (SELECT colA FROM tbl2 WHERE tbl2.id = 'someid') 
WHERE tbl1.id = 'differentid'

UPDATE tbl1 
SET col2 = (SELECT colB FROM tbl2 WHERE tbl2.id = 'someid') 
WHERE tbl1.id = 'differentid'

UPDATE tbl1 
SET col3 = (SELECT colC FROM tbl2 WHERE tbl2.id = 'someid') 
WHERE tbl1.id = 'differentid'
21
update tbl1
set col1 = a.col1, col2 = a.col2, col3 = a.col3
from tbl2 a
where tbl1.Id = 'someid'
and a.Id = 'differentid'
32
Tevo D

Cela devrait fonctionner -

    Update Tbl1 
    SET 
    Col1 = B.ColA,
    Col2 = B.ColB,
    Col3 = B.ColC
    FROM
    Tbl2 B
    Where
    B.Id = 'Someid'
7
Arun