일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
- Stock
- 6월 공모주 청약 일정
- 공모주
- Stock ipo
- java
- 자바
- MYSQL
- 공모주 청약
- codeigniter
- 제이쿼리
- php
- JavaScript
- html
- 리눅스
- jquery
- 오라클
- 7월 공모주 청약 일정
- css
- IPO
- 주식 청약
- Oracle
- 자바스크립트
- 맥
- 주식 청약 일정
- 코드이그나이터
- linux
- 공모주 청약 일정
- Eclipse
- SQL
- 주식
- Today
- Total
개발자의 끄적끄적
[MySQL] Select한 값으로 Update 본문
[MySQL] Select한 값으로 Update
단순한게는
테이블과 테이블을 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는 다 처리할 수 있지 않을까 싶다.
출처: https://lilymate.tistory.com/636 [행이네]
'개발 > sql' 카테고리의 다른 글
[Mysql] Select결과를 Update 문에 반영하기 [펌] (0) | 2020.06.28 |
---|---|
[sql] MySQL Data Truncated 경고 메시지 해결 방법 [펌] (0) | 2020.06.27 |
[MySQL] MySQL 마이그레이션 [펌] (0) | 2020.06.25 |
[mysql] insert into select [펌] (0) | 2020.06.25 |
[MySQL] 인덱스 생성, 조회 [펌] (0) | 2020.06.24 |