단순한게는

테이블과 테이블을 Join해서 특정 컬럼의 값으로 Update 시킬 수 있다.

 

UPDATE TABLE1, TABLE2
SET       TABLE1.COLUMN1 = TABLE2.COLUMN3
WHERE  TABLE1.COLUMN2 = TABLE2.COLUMN4
;



UPDATE TABLE1

            INNER JOIN TABLE2 ON TABLE1.COLUMN2 = TABLE2.COLUMN4
SET       TABLE1.COLUMN1 = TABLE2.COLUMN3
;



UPDATE TABLE1
SET    COLUMN1 = ( SELECT COLUMN2 FROM TABLE2 WHERE ... LIMIT 1 )
;

 

 

복잡하게는

Matching되는 특정 값이 존재하지 않을 경우

ROW_NUM을 만들어서 Join 시킬 수 있다.

 

UPDATE TABLE1 a3
          , ( SELECT a2.*, b2.COLUMN2
              FROM ( SELECT @rownum1 := @rownum1 + 1 AS rnum, a.COLUMN1
                         FROM   TABLE1 a JOIN ( SELECT @rownum1:=0 ) R1

                      ) a2

                    , ( SELECT @rownum2 := @rownum2 + 1 AS rnum, a.COLUMN2
                        FROM   TABLE2 a JOIN ( SELECT @rownum2:=0 ) R2

                      ) b2

             WHERE  a2.rnum = b2.rnum
           ) b3
SET       a3.COLUMN2 = b3.COLUMN2
WHERE  a3.COLUMN1 = b3.COLUMN1
;


Procedure를 굳이 만들지 않고도

웬만한 Update는 다 처리할 수 있지 않을까 싶다.



+ Recent posts