DAX Studio의 성능 문제: CallBackDataID

DAX Studio의 성능 문제: CallBackDataID

이 자습서에서는 DAX Studio의 성능 문제인 CallBackDataID 에 대해 설명합니다 . 이것이 무엇을 하고 DAX 쿼리의 성능에 어떤 영향을 미치는지 배우게 됩니다.

스토리지 엔진은 데이터 캐시의 형태로 수식 엔진에 데이터를 제공하기 위해 작동합니다. 그러나 스토리지 엔진이 식을 평가할 수 없는 경우 CallBackDataID 를 사용하여 수식 엔진에 도움을 요청하고 콜백합니다 .

계산에 CallBackDataID가 있으면 저장소와 수식 엔진을 모두 사용하기 때문에 DAX의 성능이 느려집니다. 그러나 수식 엔진만 모든 작업을 수행하는 것보다 여전히 압축된 데이터에서 수행되고 구체화가 필요하지 않기 때문에 여전히 낫습니다.

또한 수식 엔진이 관련된 경우 결과가 캐시되지 않습니다. 캐시는 LuckyTemplates에서 쿼리 또는 측정을 실행할 때 사용자 환경을 개선합니다.

목차

CallBackDataID를 찾는 위치

CallBackDataID는 DAX Studio 내부의 서버 타이밍에서 찾을 수 있습니다. 중요성 때문에 xmSQL 문에서 강조 표시됩니다. DAX를 최적화하려는 경우 CallBackDataID를 찾는 것이 가장 좋은 출발점입니다.

의 필터를 활용하는 것입니다 . 필터에서 CALCULATE를 사용하는 것이 테이블로 사용하는 것보다 낫습니다. FILTER 는 반복자이며 테이블을 필터링하면 에 의해 반복됩니다 . 이 두 반복자가 있으면 쿼리 속도가 느려질 수 있습니다.

다음은 CallBackDataID 가 있거나 없는 두 가지 샘플 쿼리입니다 .

DAX Studio의 성능 문제: CallBackDataID

이는 위의 두 쿼리를 정의하는 지역화된 측정값입니다.

DAX Studio의 성능 문제: CallBackDataID

상위 측정값은 판매 테이블을 반복하고 현재 가격과 수량을 곱한 다음 합산합니다. 맨 아래 측정값은 구매 날짜가 2016년 3월 31일보다 크거나 같은지 확인합니다. 측정값에 함수가 있으면 CALCULATE 를 사용하지 않기 때문에 CallBackDataID 가 생성됩니다 .

이를 테스트하려면 CallBackDataID 가 있는 쿼리를 실행하십시오 . 실행하기 전에 캐시를 지우고 서버 타이밍 및 쿼리 계획을 켜십시오.

하단의 Server Timings 탭을 클릭하면 첫 번째 스캔이 강조 표시되는 것을 볼 수 있습니다. 이는 CallBackDataID 가 있기 때문입니다 .

DAX Studio의 성능 문제: CallBackDataID

xmSQL 문에서 CallBackDataID를 볼 수도 있습니다 . 측정값의 IF 함수 스토리지 엔진의 기능을 벗어나므로 수식 엔진의 도움을 요청합니다.

DAX Studio의 성능 문제: CallBackDataID

성능 문제를 해결하는 방법

CallBackDataID 가 없는 쿼리를 실행하면 스캔이 더 이상 강조 표시되지 않는 것을 볼 수 있습니다.

DAX Studio의 성능 문제: CallBackDataID

이는 CALCULATE 필터가 스토리지 엔진으로 푸시다운되기 때문입니다. 자체적으로 작동할 수 있으므로 더 이상 수식 엔진의 도움이 필요하지 않습니다.

가능한 한 CALCULATE 에서 필터를 사용하십시오 . 대부분의 작업을 스토리지 엔진에 푸시하여 DAX 성능을 최적화하여 속도를 높입니다.


LuckyTemplates의 스토리지 엔진 – VertiPaq 연산자 및 쿼리
LuckyTemplates에서 측정: 최적화 팁 및 기술
DAX Studio의 VertiPaq Analyzer | 파워 BI 튜토리얼

결론

스토리지 엔진이 작동하기에 쿼리가 너무 복잡하면 성능 저하가 발생할 수 있습니다. 계산에서 CallBackDataID 와 같은 불필요한 프로세스를 가져오고 DAX 속도를 저하시킵니다. CALCULATE 에서 필터를 사용하여 완화할 수 있습니다 .


파이썬에서 자기란 무엇인가: 실제 사례

파이썬에서 자기란 무엇인가: 실제 사례

파이썬에서 자기란 무엇인가: 실제 사례

R에서 RDS 파일을 저장하고 로드하는 방법

R에서 RDS 파일을 저장하고 로드하는 방법

R의 .rds 파일에서 개체를 저장하고 로드하는 방법을 배웁니다. 이 블로그에서는 R에서 LuckyTemplates로 개체를 가져오는 방법도 다룹니다.

첫 N 영업일 재방문 – DAX 코딩 언어 솔루션

첫 N 영업일 재방문 – DAX 코딩 언어 솔루션

이 DAX 코딩 언어 자습서에서는 GENERATE 함수를 사용하는 방법과 측정값 제목을 동적으로 변경하는 방법을 알아봅니다.

LuckyTemplates에서 다중 스레드 동적 시각적 개체 기술을 사용한 인사이트 쇼케이스

LuckyTemplates에서 다중 스레드 동적 시각적 개체 기술을 사용한 인사이트 쇼케이스

이 자습서에서는 다중 스레드 동적 시각적 개체 기술을 사용하여 보고서의 동적 데이터 시각화에서 통찰력을 만드는 방법을 다룹니다.

LuckyTemplates의 컨텍스트 필터링 소개

LuckyTemplates의 컨텍스트 필터링 소개

이 기사에서는 필터 컨텍스트를 살펴보겠습니다. 필터 컨텍스트는 모든 LuckyTemplates 사용자가 처음에 배워야 하는 주요 주제 중 하나입니다.

LuckyTemplates 온라인 서비스에서 앱을 사용하기 위한 최고의 팁

LuckyTemplates 온라인 서비스에서 앱을 사용하기 위한 최고의 팁

LuckyTemplates Apps 온라인 서비스가 다양한 소스에서 생성된 다양한 보고서 및 인사이트를 관리하는 데 어떻게 도움이 되는지 보여주고 싶습니다.

시간 경과에 따른 이익 마진 변화 분석 - LuckyTemplates 및 DAX를 사용한 분석

시간 경과에 따른 이익 마진 변화 분석 - LuckyTemplates 및 DAX를 사용한 분석

LuckyTemplates에서 측정 분기 및 DAX 수식 결합과 같은 기술을 사용하여 수익 마진 변경을 해결하는 방법을 알아봅니다.

DAX Studio의 데이터 캐시에 대한 구체화 아이디어

DAX Studio의 데이터 캐시에 대한 구체화 아이디어

이 자습서에서는 데이터 캐시의 구체화 아이디어와 결과 제공 시 DAX 성능에 미치는 영향에 대해 설명합니다.

LuckyTemplates를 사용한 비즈니스 보고

LuckyTemplates를 사용한 비즈니스 보고

지금까지 Excel을 계속 사용하고 있다면 지금이 비즈니스 보고 요구 사항에 LuckyTemplates를 사용하기 시작하는 가장 좋은 시기입니다.

LuckyTemplates 게이트웨이란? 당신이 알아야 할 모든 것

LuckyTemplates 게이트웨이란? 당신이 알아야 할 모든 것

LuckyTemplates 게이트웨이란? 당신이 알아야 할 모든 것