> 데이터 베이스 > MySQL 튜토리얼 > LEFT JOIN을 사용하여 여러 MySQL 테이블을 어떻게 업데이트할 수 있나요?

LEFT JOIN을 사용하여 여러 MySQL 테이블을 어떻게 업데이트할 수 있나요?

Barbara Streisand
풀어 주다: 2024-12-06 12:37:11
원래의
813명이 탐색했습니다.

How Can I Update Multiple MySQL Tables Using a LEFT JOIN?

MySQL에서 LEFT JOIN을 사용하여 여러 테이블 업데이트

MySQL을 사용하면 사용자는 LEFT JOIN을 포함한 다양한 유형의 조인을 사용하여 다중 테이블 업데이트를 수행할 수 있습니다. . 그러나 이러한 업데이트 구문은 파악하기 어려울 수 있습니다.

LEFT JOIN을 사용하여 여러 테이블을 업데이트하는 구문

LEFT JOIN을 사용하여 여러 테이블을 업데이트하려면 다음 구문을 사용할 수 있습니다. 채용:

UPDATE  t1
LEFT JOIN
        t2
ON      t2.id = t1.id
SET     t1.col1 = newvalue
WHERE   t2.id IS NULL
로그인 후 복사

여기서 구문:

  • t1t2은 업데이트되는 테이블을 나타냅니다.
  • LEFT JOIN ​​절은 조건에 따른 테이블 간의 관계(t2.id = 이 예에서는 t1.id).
  • SET 절은 대상 테이블 t1에서 업데이트할 열과 해당 새 값을 지정합니다.
  • WHERE 절은 기준에 따라 조인된 결과 집합의 행을 필터링합니다. 이 경우 t2에 존재하지 않는 t1의 행을 식별합니다(t2.id IS NULL).

성능 고려사항

왼쪽에 있다는 점에 유의하는 것이 중요합니다. JOIN 업데이트는 데이터 선택에 NOT IN ​​구문을 사용하는 것에 비해 효율성이 떨어집니다. 예를 들어 불완전한 주문을 효율적으로 식별하기 위한 더 나은 접근 방식은 다음 구문을 사용하는 것입니다.

SELECT  t1.*
FROM    t1
WHERE   t1.id NOT IN
        (
        SELECT  id
        FROM    t2
        )
로그인 후 복사

그러나 UPDATE 문의 경우 MySQL은 대상 테이블이 하위 쿼리에 사용되는 것을 허용하지 않습니다. 따라서 다중 테이블 업데이트에는 덜 효율적인 LEFT JOIN 구문을 사용해야 합니다.

위 내용은 LEFT JOIN을 사용하여 여러 MySQL 테이블을 어떻게 업데이트할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿