> 데이터 베이스 > MySQL 튜토리얼 > CTE(공통 테이블 표현식)에서 계산된 값을 사용하여 테이블 레코드를 업데이트하려면 어떻게 해야 합니까?

CTE(공통 테이블 표현식)에서 계산된 값을 사용하여 테이블 레코드를 업데이트하려면 어떻게 해야 합니까?

Susan Sarandon
풀어 주다: 2025-01-08 14:36:41
원래의
164명이 탐색했습니다.

How Can I Update Table Records Using Values Calculated in a Common Table Expression (CTE)?

일반 표현식(CTE)을 사용하여 레코드 업데이트

CTE를 사용하여 테이블 레코드를 업데이트하는 경우 CTE의 특성에 주의하세요. CTE는 정의된 쿼리 중에만 존재하는 임시 컬렉션입니다. 따라서 CTE에 대한 변경 사항은 소스 테이블에 직접적인 영향을 미치지 않습니다.

이러한 한계를 극복하려면 CTE를 기반으로 레코드를 업데이트하는 다른 접근 방식이 필요합니다. 효율적인 접근 방식은 CTE에 하위 쿼리를 만들어 필요한 값을 계산하는 것입니다. 그런 다음 이 하위 쿼리를 UPDATE 문에서 사용하여 계산된 값을 대상 테이블에 적용할 수 있습니다.

CTE에서 계산된 값을 기반으로 PEDI_InvoiceDetail 테이블의 DocTotal 열을 업데이트하려는 다음 예를 고려해 보세요.

<code class="language-sql">;WITH CTE_DocTotal AS
(
  SELECT InvoiceNumber, SUM(Sale + VAT) AS DocTotal
  FROM PEDI_InvoiceDetail
  GROUP BY InvoiceNumber
)</code>
로그인 후 복사

이 CTE는 각 InvoiceNumber에 대해 DocTotal을 계산하고 결과를 임시 컬렉션에 저장합니다. PEDI_InvoiceDetail 테이블을 이러한 값으로 업데이트하려면 CTE에서 하위 쿼리를 사용할 수 있습니다.

<code class="language-sql">;WITH T AS
(
  SELECT InvoiceNumber,
          SUM(Sale + VAT) OVER(PARTITION BY InvoiceNumber) AS NewDocTotal
  FROM PEDI_InvoiceDetail
)
UPDATE T
SET DocTotal = NewDocTotal</code>
로그인 후 복사

이 하위 쿼리에서 OVER 절이 있는 SUM() 함수는 InvoiceNumber으로 정의된 각 파티션(그룹)에 대해 새로운 DocTotal을 계산합니다. 그런 다음 이 하위 쿼리는 T로 별칭이 지정되고 UPDATE 문에서 사용되어 DocTotal 열을 계산된 값으로 업데이트합니다.

이 접근 방식을 사용하면 CTE에서 계산된 값을 기반으로 PEDI_InvoiceDetail 테이블의 레코드를 효과적으로 업데이트하여 변경 사항이 소스 테이블에 유지되도록 할 수 있습니다.

위 내용은 CTE(공통 테이블 표현식)에서 계산된 값을 사용하여 테이블 레코드를 업데이트하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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