MySQL에서 누계를 효율적으로 계산하는 방법은 무엇입니까?
Jan 22, 2025 am 06:26 AMMySQL 누적 합계: 사용자 변수를 사용한 솔루션
원래 "MySQL에서 누계 계산"이라는 제목의 이 문서는 이전 열 값의 누적 합계를 표시하는 테이블에 열을 추가하기 위한 것입니다. 그러나 제공된 답변에 따르면 표현식에서 사용자 변수를 사용하는 것은 이제 더 이상 사용되지 않으며 향후 버전에서는 제거될 예정입니다. 따라서 우리는 누계 변수를 초기화하고 수학적 계산을 사용하여 단일 쿼리를 실행하여 원하는 결과를 얻는 더 간단한 솔루션을 제공합니다.
제공되는 쿼리는 다음과 같습니다.
SET @runtot:=0; SELECT q1.d, q1.c, (@runtot := @runtot + q1.c) AS rt FROM (SELECT DAYOFYEAR(`date`) AS d, COUNT(*) AS c FROM `orders` WHERE `hasPaid` > 0 GROUP BY d ORDER BY d) AS q1
이 쿼리는 먼저 SET 문을 사용하여 @runtot 사용자 변수를 0으로 초기화합니다. 그런 다음 하위 쿼리를 실행하여 주문 테이블에서 필요한 데이터를 검색합니다. 마지막으로 외부 쿼리는 하위 쿼리의 결과를 누계 계산과 결합합니다.
결과 테이블에는 각 행의 c열에 대한 누계를 나타내는 rt라는 추가 열이 포함됩니다. 이 솔루션은 식에서 더 이상 사용되지 않는 사용자 변수를 사용하지 않고 단일 쿼리 실행을 통해 보다 효율적인 접근 방식을 제공합니다.
위 내용은 MySQL에서 누계를 효율적으로 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

인기 기사

인기 기사

뜨거운 기사 태그

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까?

MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다.

Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음)

일반적인 취약점 (SQL 주입, 무차별 적 공격)에 대해 MySQL을 어떻게 보호합니까?
