sql-server - three - update set join sql server




Aggiorna una tabella utilizzando JOIN in SQL Server? (7)

Voglio aggiornare una colonna in una tabella facendo un join su un'altra tabella, ad esempio:

UPDATE table1 a 
INNER JOIN table2 b ON a.commonfield = b.[common field] 
SET a.CalculatedColumn= b.[Calculated Column]
WHERE 
    b.[common field]= a.commonfield
AND a.BatchNO = '110'

Ma si lamenta:

Messaggio 170, livello 15, stato 1, riga 2
Riga 2: sintassi errata vicino a 'a'.

Cosa c'è di sbagliato qui?


Ho avuto lo stesso problema .. e non è necessario aggiungere una colonna fisica .. perché ora dovrai mantenerla .. quello che puoi fare è aggiungere una colonna generica nella query di selezione:

EX:

select tb1.col1, tb1.col2, tb1.col3 ,
( 
select 'Match' from table2 as tbl2
where tbl1.col1 = tbl2.col1 and tab1.col2 = tbl2.col2
)  
from myTable as tbl1

La risposta fornita da Aaron è perfetta:

UPDATE a
  SET a.CalculatedColumn = b.[Calculated Column]
  FROM Table1 AS a
  INNER JOIN Table2 AS b
  ON a.CommonField = b.[Common Field]
  WHERE a.BatchNo = '110';

Voglio solo aggiungere il motivo per cui questo problema si verifica in SQL Server quando proviamo a utilizzare l'alias di una tabella durante l'aggiornamento di quella tabella, la sintassi di seguito riportata darà sempre un errore:

update tableName t 
set t.name = 'books new' 
where t.id = 1

il caso può essere qualsiasi se si aggiorna una singola tabella o si aggiorna durante l'utilizzo di join.

Sebbene la query sopra funzionerà correttamente in PL / SQL ma non in SQL Server.

Il modo corretto per aggiornare una tabella mentre si utilizza l'alias di tabella in SQL Server è:

update t 
set t.name = 'books new' 
from tableName t 
where t.id = 1

Spero che possa aiutare tutti perché l'errore è arrivato qui.


Provalo in questo modo:

begin tran
    UPDATE a 
    SET a.CalculatedColumn= b.[Calculated Column]
    FROM table1 a INNER JOIN table2 b ON a.commonfield = b.[common field] 
    WHERE a.BatchNO = '110'
commit tran

(modifica: darn typos!)


Provare:

UPDATE table1
SET CalculatedColumn = ( SELECT [Calculated Column] 
                         FROM table2 
                         WHERE table1.commonfield = [common field])
WHERE  BatchNO = '110'

Trovo utile trasformare un UPDATE in un SELECT per ottenere le righe che voglio aggiornare come test prima dell'aggiornamento. Se riesco a selezionare le righe esatte che desidero, posso aggiornare solo le righe che voglio aggiornare.

DECLARE @expense_report_id AS INT
SET @expense_report_id = 1027

--UPDATE expense_report_detail_distribution
--SET service_bill_id = 9

SELECT *
FROM expense_report_detail_distribution erdd
INNER JOIN expense_report_detail erd
INNER JOIN expense_report er 
    ON er.expense_report_id = erd.expense_report_id 
    ON erdd.expense_report_detail_id = erd.expense_report_detail_id
WHERE er.expense_report_id = @expense_report_id

Un altro approccio sarebbe usare MERGE

  ;WITH cteTable1(CalculatedColumn, CommonField)
  AS
  (
    select CalculatedColumn, CommonField from Table1 Where BatchNo = '110'
  )
  MERGE cteTable1 AS target
    USING (select "Calculated Column", "Common Field" FROM dbo.Table2) AS source ("Calculated Column", "Common Field")
    ON (target.CommonField = source."Common Field")
    WHEN MATCHED THEN 
        UPDATE SET target.CalculatedColumn = source."Calculated Column";

-Merge fa parte dello standard SQL

-Inoltre sono abbastanza sicuro che gli aggiornamenti di inner join non sono deterministici. Domanda simile qui dove la risposta parla di http://ask.sqlservercentral.com/questions/19089/updating-two-tables-using-single-query.html


MERGE table1 T
   USING table2 S
      ON T.CommonField = S."Common Field"
         AND T.BatchNo = '110'
WHEN MATCHED THEN
   UPDATE
      SET CalculatedColumn = S."Calculated Column";






sql-update