집 >데이터 베이스 >MySQL 튜토리얼 >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 중국어 웹사이트의 기타 관련 기사를 참조하세요!