반응형
업데이트 쿼리에서 3 테이블 조인을 수행하는 방법은 무엇입니까?
나는 질문을하고 도움이 회신을 받았습니다.
UPDATE TABLE_A a JOIN TABLE_B b
ON a.join_col = b.join_col AND a.column_a = b.column_b
SET a.column_c = a.column_c + 1
이제 이와 같은 3 개의 테이블이 있으면이 작업을 수행하려고합니다.
UPDATE tableC c JOIN tableB b JOIN tableA a
내 질문은 기본적으로 ...이 UPDATE
문장 에서 3 테이블 조인을 수행 할 수 있습니까? 올바른 구문은 무엇입니까? 감사합니다. 내가합니까 ...
JOIN tableB, tableA
JOIN tableB JOIN tableA
대답은 yes
당신 이 할 수 있다는 것입니다
그렇게 해봐
UPDATE TABLE_A a
JOIN TABLE_B b ON a.join_col = b.join_col AND a.column_a = b.column_b
JOIN TABLE_C c ON [condition]
SET a.column_c = a.column_c + 1
편집하다:
일반적인 업데이트 가입 :
UPDATE TABLEA a
JOIN TABLEB b ON a.join_colA = b.join_colB
SET a.columnToUpdate = [something]
동일한 결과 를 얻는 다른 방법은 JOIN
키워드를 전혀 사용하지 않는 것입니다.
UPDATE TABLE_A, TABLE_B
SET TABLE_A.column_c = TABLE_B.column_c + 1
WHERE TABLE_A.join_col = TABLE_B.join_col
아래는 JOIN
& WHERE
모두 를 포함하는 업데이트 쿼리입니다 . 여러 조인 / where 절을 사용할 수있는 것과 같은 방법으로 도움이되기를 바랍니다.
UPDATE opportunities_cstm oc JOIN opportunities o ON oc.id_c = o.id
SET oc.forecast_stage_c = 'APX'
WHERE o.deleted = 0
AND o.sales_stage IN('ABC','PQR','XYZ')
폭발적인 "답변에 대한 의견"은 아직 완료되지 않은 경우에도 전체 편집 내용을 게시하지 않고 줄 바꿈을 수행하지 않기 때문에 독립적 인 답변으로 만 추가하는 대체 일반 계획입니다.
UPDATE table A
JOIN table B ON {join fields}
JOIN table C ON {join fields}
JOIN {as many tables as you need}
SET A.column = {expression}
예:
UPDATE person P
JOIN address A ON P.home_address_id = A.id
JOIN city C ON A.city_id = C.id
SET P.home_zip = C.zipcode;
PostgreSQL 예제의 경우 :
UPDATE TableA AS a
SET param_from_table_a=FALSE -- param FROM TableA
FROM TableB AS b
WHERE b.id=a.param_id AND a.amount <> 0;
참고 URL : https://stackoverflow.com/questions/15209414/how-to-do-3-table-join-in-update-query
반응형
'Programing' 카테고리의 다른 글
왜 조각 대신 활동 대신 조각을 사용해야합니까? (0) | 2020.02.17 |
---|---|
공백을 플러스 (+) 또는 % 20으로 인코딩 할 때 (0) | 2020.02.17 |
리스트의 문자열 표현을리스트로 변환 (0) | 2020.02.17 |
방법 : C #에서 명령 줄 실행, STD OUT 결과 가져 오기 (0) | 2020.02.17 |
플랫폼이 동일하더라도 "잘못된 형식의 프로그램을로드하려고했습니다" (0) | 2020.02.17 |