mysql에서 필드 합계를 구현하는 방법
mysql에서는 SUM() 함수를 사용하여 필드 합계를 구현할 수 있습니다. 이 함수는 지정된 필드 값의 합계를 반환합니다. 구문은 "SELECT SUM(DISTINCT 표현식) FROM 테이블 이름 [WHERE 절];)"입니다.
이 튜토리얼의 운영 환경: windows7 시스템, mysql8 버전, Dell G3 컴퓨터.
mysql에서는 SUM() 함수를 사용하여 필드 합계를 구현할 수 있습니다.
SUM()
함수는 값 또는 표현식 세트의 합계를 계산하는 데 사용되며 지정된 필드 값의 합계를 반환할 수 있습니다. SUM( )
함수는 다음과 같습니다. SUM()
函数用于计算一组值或表达式的总和,可返回指定字段值的总和,SUM()
函数的语法如下:
SUM(DISTINCT expression)
SUM()
函数是如何工作的?
- 如果在没有返回匹配行
SELECT
语句中使用SUM
函数,则SUM
函数返回NULL
,而不是0
。 -
DISTINCT
运算符允许计算集合中的不同值。 -
SUM
函数忽略计算中的NULL
值。
MySQL SUM()函数示例
我们来看看示例数据库(yiibaidb)中的orderdetails
表。
可以使用SUM()
函数来计算订单编号10100
的总金额,如下查询所示:
SELECT FORMAT(SUM(quantityOrdered * priceEach),2) total FROM orderdetails WHERE orderNumber = 10100;
执行上面查询语句,得到以下结果 -
mysql> SELECT FORMAT(SUM(quantityOrdered * priceEach),2) total FROM orderdetails WHERE orderNumber = 10100; +-----------+ | total | +-----------+ | 10,223.83 | +-----------+ 1 row in set
请注意,FORMAT()
函数用于格式化SUM()
函数的返回值。
MySQL SUM与GROUP BY子句
当与GROUP BY
子句组合时,SUM()
函数计算GROUP BY
子句中指定的每个分组的总和。
例如,可以使用具有GROUP BY
子句的SUM
函数计算每个订单的总金额,如下所示:
SELECT orderNumber, FORMAT(SUM(quantityOrdered * priceEach),2) total FROM orderdetails GROUP BY orderNumber ORDER BY SUM(quantityOrdered * priceEach) DESC;
执行上面查询语句,得到以下结果 -
+-------------+-----------+ | orderNumber | total | +-------------+-----------+ | 10165 | 67,392.85 | | 10287 | 61,402.00 | | 10310 | 61,234.67 | | 10212 | 59,830.55 | *** 此处省略了一大波数据 ***** | 10116 | 1,627.56 | | 10158 | 1,491.38 | | 10144 | 1,128.20 | | 10408 | 615.45 | +-------------+-----------+ 327 rows in set
MySQL SUM与HAVING
您可以使用HAVING
子句中在SUM
函数中来根据特定条件过滤结果。例如,您可以计算总订单量,只能选择总金额大于60000
的订单。如下查询语句 -
SELECT orderNumber, FORMAT(SUM(quantityOrdered * priceEach),2) FROM orderdetails GROUP BY orderNumber HAVING SUM(quantityOrdered * priceEach) > 60000 ORDER BY SUM(quantityOrdered * priceEach);
执行上面查询语句,得到以下结果 -
mysql> SELECT orderNumber, FORMAT(SUM(quantityOrdered * priceEach),2) FROM orderdetails GROUP BY orderNumber HAVING SUM(quantityOrdered * priceEach) > 60000 ORDER BY SUM(quantityOrdered * priceEach); +-------------+--------------------------------------------+ | orderNumber | FORMAT(SUM(quantityOrdered * priceEach),2) | +-------------+--------------------------------------------+ | 10310 | 61,234.67 | | 10287 | 61,402.00 | | 10165 | 67,392.85 | +-------------+--------------------------------------------+ 3 rows in set
MySQL SUM与LIMIT
假设您想要计算products
表中前十名最昂贵的产品的总和,可以提出以下查询:
SELECT SUM(buyprice) FROM products ORDER BY buyprice DESC LIMIT 10;
执行上面查询语句,得到以下结果 -
mysql> SELECT SUM(buyprice) FROM products ORDER BY buyprice DESC LIMIT 10; +---------------+ | SUM(buyprice) | +---------------+ | 5983.47 | +---------------+ 1 row in set
它不起作用,因为具有SUM
函数的SELECT
语句只返回一行,LIMIT
子句约束要返回的行数无效。
要解决此问题,请使用以下子查询:
SELECT FORMAT(SUM(buyprice),2) FROM (SELECT buyprice FROM products ORDER BY buyprice DESC LIMIT 10) price;
执行上面查询语句,得到以下结果 -
+-------------------------+ | FORMAT(SUM(buyprice),2) | +-------------------------+ | 958.71 | +-------------------------+ 1 row in set
上面语句是怎么运行的?
- 子查询选择十大价格最高的产品。
- 外部查询计算从子查询返回的前
10
个价格最高的产品的总和。
MySQL SUM与NULL
如果没有匹配的行,则SUM
函数返回NULL
值。 有时,您希望SUM
函数返回0
而不是NULL
。 在这种情况下,可以使用COALESCE
函数。COALESCE
函数接受两个参数,如果第一个参数为NULL
,则返回第二个参数,否则返回第一个参数; 参考以下查询语句:
SELECT COALESCE(SUM(quantityOrdered * priceEach),0) FROM orderdetails WHERE productCode = 'S1_212121';
执行上面查询语句,得到以下结果 -
mysql> SELECT COALESCE(SUM(quantityOrdered * priceEach),0) FROM orderdetails WHERE productCode = 'S1_212121'; +----------------------------------------------+ | COALESCE(SUM(quantityOrdered * priceEach),0) | +----------------------------------------------+ | 0.00 | +----------------------------------------------+ 1 row in set
MySQL SUM与连接语句
您可以使用SELECT
JOIN
语句中的SUM
SELECT FORMAT(SUM(quantityOrdered * priceEach),2) loss FROM orderdetails INNER JOIN orders USING(orderNumber) WHERE status = 'Cancelled'
SUM()
함수는 어떻게 작동하나요?
- 일치하는 행을 반환하지 않는
SELECT
문에서SUM
함수를 사용하는 경우SUM
함수는 NULL,0
이 아닙니다. -
DISTINCT
연산자를 사용하면 컬렉션의 고유한 값을 계산할 수 있습니다. -
SUM
함수는 계산 시NULL
값을 무시합니다.
MySQL SUM() 함수 예제
샘플 데이터베이스의orderdetails
를 살펴보겠습니다( yiibaidb) >테이블. 다음 쿼리에 표시된 대로 SUM()
함수를 사용하여 주문 번호 10100
의 총액을 계산할 수 있습니다. rrreee
FORMAT()
함수는 SUM()
함수의 반환 값 형식을 지정하는 데 사용됩니다. 🎜🎜GROUP BY 절이 있는 MySQL SUM 🎜
🎜GROUP BY
절과 결합하면 SUM()
함수는 GROUP BY
절에 지정된 각 그룹의 합계를 계산합니다. 🎜🎜예를 들어 GROUP BY
절과 함께 SUM
함수를 사용하면 아래와 같이 각 주문의 총액을 계산할 수 있습니다. 🎜rrreee🎜위 쿼리를 실행합니다. 문을 실행하고 다음 결과를 얻습니다. - 🎜rrreeeMySQL SUM과 HAVING
🎜SUM에서 <code>HAVING
절을 사용할 수 있습니다. 함수는 특정 기준에 따라 결과를 필터링합니다. 예를 들어 총 주문 수량을 계산하고 총 금액이 60000
보다 큰 주문만 선택할 수 있습니다. 다음 쿼리문 -🎜rrreee🎜위 쿼리문을 실행하여 다음과 같은 결과를 얻습니다. -🎜rrreee🎜MySQL SUM 및 LIMIT🎜
🎜원한다고 가정해보세요products
테이블에서 가장 비싼 상위 10개 제품의 합계를 계산하면 다음 쿼리가 요청될 수 있습니다. 🎜rrreee🎜위 쿼리 문을 실행하고 다음 결과를 얻습니다.🎜rrreee🎜작동하지 않습니다. SUM함수의 <code>SELECT
문은 하나의 행만 반환하고 LIMIT
절은 반환할 행 수를 제한하므로 유효하지 않습니다. . 🎜🎜이 문제를 해결하려면 다음 하위 쿼리를 사용하세요. 🎜rrreee🎜위 쿼리 문을 실행하여 다음과 같은 결과를 얻습니다. -🎜rrreee🎜위 문은 어떻게 실행되나요? 🎜- 하위 쿼리는 가장 비싼 제품 상위 10개를 선택합니다.
- 외부 쿼리는 하위 쿼리에서 반환된 가격이 가장 높은 상위
10
제품의 합계를 계산합니다.
🎜MySQL SUM 및 NULL🎜
🎜일치하는 행이 없으면SUM
함수 NULL
값을 반환합니다. SUM
함수가 NULL
대신 0
을 반환하기를 원하는 경우가 있습니다. 이 경우 COALESCE
기능을 사용할 수 있습니다. COALESCE
함수는 두 개의 매개변수를 허용합니다. 첫 번째 매개변수가 NULL
이면 두 번째 매개변수를 반환하고, 그렇지 않으면 다음 쿼리 문을 참조하세요. 🎜위 쿼리문을 실행하여 다음과 같은 결과를 얻습니다-🎜rrreeeMySQL SUM 및 연결문
🎜SELECT
JOIN
문의 SUM
함수는 다른 테이블의 값으로 지정된 조건을 기반으로 테이블의 값 합계를 계산합니다. 🎜🎜예를 들어 취소된 총 주문 금액을 계산하려면 다음 문을 사용하세요. 🎜rrreee🎜[관련 권장 사항: 🎜mysql video tutorial🎜]🎜위 내용은 mysql에서 필드 합계를 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

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

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

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

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

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

뜨거운 주제











다음 단계를 통해 phpmyadmin을 열 수 있습니다. 1. 웹 사이트 제어판에 로그인; 2. phpmyadmin 아이콘을 찾고 클릭하십시오. 3. MySQL 자격 증명을 입력하십시오. 4. "로그인"을 클릭하십시오.

MySQL은 오픈 소스 관계형 데이터베이스 관리 시스템으로, 주로 데이터를 신속하고 안정적으로 저장하고 검색하는 데 사용됩니다. 작업 원칙에는 클라이언트 요청, 쿼리 해상도, 쿼리 실행 및 반환 결과가 포함됩니다. 사용의 예로는 테이블 작성, 데이터 삽입 및 쿼리 및 조인 작업과 같은 고급 기능이 포함됩니다. 일반적인 오류에는 SQL 구문, 데이터 유형 및 권한이 포함되며 최적화 제안에는 인덱스 사용, 최적화 된 쿼리 및 테이블 분할이 포함됩니다.

데이터베이스 및 프로그래밍에서 MySQL의 위치는 매우 중요합니다. 다양한 응용 프로그램 시나리오에서 널리 사용되는 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 1) MySQL은 웹, 모바일 및 엔터프라이즈 레벨 시스템을 지원하는 효율적인 데이터 저장, 조직 및 검색 기능을 제공합니다. 2) 클라이언트 서버 아키텍처를 사용하고 여러 스토리지 엔진 및 인덱스 최적화를 지원합니다. 3) 기본 사용에는 테이블 작성 및 데이터 삽입이 포함되며 고급 사용에는 다중 테이블 조인 및 복잡한 쿼리가 포함됩니다. 4) SQL 구문 오류 및 성능 문제와 같은 자주 묻는 질문은 설명 명령 및 느린 쿼리 로그를 통해 디버깅 할 수 있습니다. 5) 성능 최적화 방법에는 인덱스의 합리적인 사용, 최적화 된 쿼리 및 캐시 사용이 포함됩니다. 모범 사례에는 거래 사용 및 준비된 체계가 포함됩니다

MySQL은 성능, 신뢰성, 사용 편의성 및 커뮤니티 지원을 위해 선택됩니다. 1.MYSQL은 효율적인 데이터 저장 및 검색 기능을 제공하여 여러 데이터 유형 및 고급 쿼리 작업을 지원합니다. 2. 고객-서버 아키텍처 및 다중 스토리지 엔진을 채택하여 트랜잭션 및 쿼리 최적화를 지원합니다. 3. 사용하기 쉽고 다양한 운영 체제 및 프로그래밍 언어를 지원합니다. 4. 강력한 지역 사회 지원을 받고 풍부한 자원과 솔루션을 제공합니다.

Apache는 데이터베이스에 연결하여 다음 단계가 필요합니다. 데이터베이스 드라이버 설치. 연결 풀을 만들려면 Web.xml 파일을 구성하십시오. JDBC 데이터 소스를 작성하고 연결 설정을 지정하십시오. JDBC API를 사용하여 Connections, 명세서 작성, 매개 변수 바인딩, 쿼리 또는 업데이트 실행 및 처리를 포함하여 Java 코드의 데이터베이스에 액세스하십시오.

Docker에서 MySQL을 시작하는 프로세스는 다음 단계로 구성됩니다. MySQL 이미지를 가져와 컨테이너를 작성하고 시작하고 루트 사용자 암호를 설정하고 포트 확인 연결을 매핑하고 데이터베이스를 작성하고 사용자는 데이터베이스에 모든 권한을 부여합니다.

웹 응용 프로그램에서 MySQL의 주요 역할은 데이터를 저장하고 관리하는 것입니다. 1. MySQL은 사용자 정보, 제품 카탈로그, 트랜잭션 레코드 및 기타 데이터를 효율적으로 처리합니다. 2. SQL 쿼리를 통해 개발자는 데이터베이스에서 정보를 추출하여 동적 컨텐츠를 생성 할 수 있습니다. 3.mysql은 클라이언트-서버 모델을 기반으로 작동하여 허용 가능한 쿼리 속도를 보장합니다.

Centos에 MySQL을 설치하려면 다음 단계가 필요합니다. 적절한 MySQL Yum 소스 추가. mysql 서버를 설치하려면 yum install mysql-server 명령을 실행하십시오. mysql_secure_installation 명령을 사용하여 루트 사용자 비밀번호 설정과 같은 보안 설정을 작성하십시오. 필요에 따라 MySQL 구성 파일을 사용자 정의하십시오. MySQL 매개 변수를 조정하고 성능을 위해 데이터베이스를 최적화하십시오.
