DSum 함수

DSUM 함수를 사용하면 지정된 레코드 집합, 즉 도메인의 값 집합의 합계를 계산할 수 있습니다. VBA(Visual Basic for Applications) 모듈, 매크로, 쿼리 식 또는 계산된 컨트롤에 DSUM 함수를 사용할 수 있습니다.

예를 들어 DSum 함수를 쿼리의 계산 필드 식에 사용하여 일정 기간 동안 특정 직원이 달성한 총 판매량을 계산하거나, DSum 함수를 계산 컨트롤에 사용하여 특정 제품의 판매량 누적 합계를 표시할 수 있습니다.

구문

DSum ( expr , domain [, criteria] )

DSum 함수 구문에는 다음과 같은 인수가 있습니다.

인수

설명

expr

필수 요소로서 합계를 계산할 값이 들어 있는 숫자 필드를 식별하는 식입니다. 이 인수는 테이블 또는 쿼리의 필드를 식별하는 문자열 식일 수도 있고 해당 필드의 데이터에 대해 계산을 수행하는 식일 수도 있습니다. expr에는 테이블의 필드 이름, 폼의 컨트롤, 상수 또는 함수를 포함할 수 있습니다. expr에는 기본 제공 함수나 사용자 정의 함수는 포함할 수 있지만 다른 도메인 집계 함수나 SQL 집계 함수는 포함할 수 없습니다.

domain

필수 요소로서 도메인을 구성하는 레코드 집합을 식별하는 문자열 식입니다. 테이블 이름을 사용하거나 매개 변수가 필요 없는 쿼리의 이름을 사용할 수 있습니다.

criteria

선택 요소로서 DSum 함수로 계산을 수행할 데이터의 범위를 제한하는 문자열 식입니다. 예를 들어 criteria는 보통 SQL 식의 WHERE 절에서 WHERE 단어를 뺀 것과 같습니다. criteria를 생략하면 DSum 함수는 전체 도메인에 대해 expr을 계산합니다. criteria에 포함되는 모든 필드는 domain의 필드여야 하며, 그렇지 않은 경우 DSum 함수는 Null을 반환합니다.


주의

criteria 인수를 충족하는 레코드가 없거나 도메인에 레코드가 없으면 DSum 함수는 Null을 반환합니다.

DSum 함수를 매크로, 모듈, 쿼리 식 또는 계산 컨트롤 중 어디에 사용하는지에 관계없이 criteria 인수를 주의 깊게 작성하여 이 인수가 올바르게 계산되도록 해야 합니다.

쿼리의 조건 행, 쿼리 식의 계산 필드 또는 업데이트 쿼리의 업데이트 행에서 조건을 지정하기 위해 DSum 함수를 사용할 수 있습니다.

참고: 요약 쿼리의 계산 필드 식에 DSum 또는 Sum 함수를 사용할 수 있습니다. DSum 함수를 사용하면 데이터가 그룹화되기 전에 값의 평균이 계산되고 Sum 함수를 사용하면 데이터가 그룹화된 후에 필드 식 값이 계산됩니다.

폼이나 보고서의 레코드 원본에 없는 필드의 값 집합 합계를 표시해야 하는 경우 DSum을 사용할 수 있습니다. 예를 들어 특정 제품에 대한 정보를 표시하는 폼이 있으면 DSum 함수를 사용하여 해당 제품의 판매량 누적 합계를 계산 컨트롤에 표시할 수 있습니다.

누계를 보고서의 컨트롤에 표시해야 하는 경우 컨트롤의 기반이 되는 필드가 보고서의 레코드 원본에 포함되어 있다면 해당 컨트롤의 RunningSum 속성을 사용할 수 있습니다. 누적 합계를 폼에 표시하려면 DSum 함수를 사용합니다.

참고: 이 함수에서는 domain의 레코드에 대한 변경 내용이 저장되지 않은 경우 해당 내용을 고려하지 않습니다. DSum 함수가 변경된 값을 기준으로 계산을 수행하도록 하려면 먼저 탭의 레코드 그룹에서 레코드 저장을 클릭하고 포커스를 다른 레코드로 이동하거나 Update 메서드를 사용하여 변경 내용을 저장해야 합니다.

예제

식에서 DSum 함수 사용    도메인 함수 DSum 등을 업데이트 쿼리의 업데이트 행에 사용할 수 있습니다. 예를 들어 Products 테이블에 있는 제품별로 현재 판매액을 추적하려는 경우 Products 테이블에 SalesSoFar라는 새 필드를 추가하고 업데이트 쿼리를 실행하면 올바른 값을 계산하고 레코드를 업데이트할 수 있습니다. 이렇게 하려면 Products 테이블을 기반으로 새 쿼리를 만들고 디자인 탭의 쿼리 유형 그룹에서 업데이트를 클릭합니다. SalesSoFar 필드를 쿼리 눈금에 추가하고 다음 코드를 업데이트 행에 입력합니다.

DSum("[Quantity]*[UnitPrice]", "Order Details", _
"[ProductID] = "& [ProductID])

쿼리를 실행하면 Order Details 테이블의 정보를 기준으로 각 제품의 총 판매액이 계산됩니다. 각 제품의 판매액 합계는 Products 테이블에 추가됩니다.

VBA 코드에 DSum 사용   

참고: VBA(Visual Basic for Applications) 모듈에서 이 함수를 사용하는 경우를 예로 들어 보겠습니다. VBA 사용에 대해 자세히 알아보려면 검색 옆의 드롭다운 목록에서 개발자 참고를 선택하고 검색 상자에 검색어를 하나 이상 입력하세요.

다음은 Freight 필드에 있는 영국으로 선적된 주문에 대한 값의 총계를 계산하는 예제입니다. 도메인은 Orders 테이블입니다. criteria 인수는 결과 레코드 집합을 ShipCountryRegion이 UK인 레코드로 제한합니다.

Dim curX As Currency
curX = DSum("[Freight]", "Orders", _
"[ShipCountryRegion] = 'UK'")

다음은 두 가지 조건을 사용하여 총계를 계산하는 예제입니다. 여기에서는 문자열 식에 작은따옴표(') 및 파운드 기호(#)가 들어 있으므로 문자열을 연결할 때 문자열 리터럴은 작은따옴표로 묶이고 날짜는 파운드 기호로 묶입니다.

Dim curX As Currency
curX = DSum("[Freight]", "Orders", _
"[ShipCountryRegion] = 'UK' AND _
[ShippedDate] > #1-1-95#")
Office 기술 확장
교육 살펴보기
새로운 기능 우선 가져오기
Office Insider 참여

이 정보가 유용한가요?

의견 주셔서 감사합니다!

피드백을 주셔서 감사합니다. Office 지원 에이전트와 연락하는 것이 도움이 될 것 같습니다.

×