다음을 통해 공유


COMBINEVALUES

적용 대상:계산 열계산 테이블측정값시각적 계산

두 개 이상의 텍스트 문자열을 하나의 텍스트 문자열에 조인합니다. 이 함수의 주요 목적은 DirectQuery 모델에서 다중 열 관계를 지원하는 것입니다. 자세한 내용은 설명 참조하세요.

통사론

COMBINEVALUES(<delimiter>, <expression>, <expression>[, <expression>]…)

매개 변수

학기 정의
delimiter 연결 중에 사용할 구분 기호입니다. 상수 값이어야 합니다.
expression 값이 단일 텍스트 문자열에 조인되는 DAX 식입니다.

반환 값

연결된 문자열입니다.

발언

  • COMBINEVALUES 함수는 입력 값이 다를 때 출력 문자열도 다르다고 가정하지만 유효성을 검사하지는 않습니다. 이 가정에 따라 COMBINEVALUES 두 DirectQuery 테이블에서 여러 열을 조인하는 관계를 구축하기 위해 계산 열을 만드는 데 사용되는 경우 쿼리 시 최적화된 조인 조건이 생성됩니다. 예를 들어 Table1(Column1, Column2)과 Table2(Column1, Column2) 간에 관계를 만들려는 경우 다음과 같이 각 테이블에 하나씩 두 개의 계산 열을 만들 수 있습니다.

    Table1[CalcColumn] = COMBINEVALUES(",", Table1[Column1], Table1[Column2])
    

    그리고

    Table2[CalcColumn] = COMBINEVALUES(",", Table2[Column1], Table2[Column2])
    

    그런 다음 Table1[CalcColumn]Table2[CalcColumn]간에 관계를 만듭니다. 리터럴 그대로 해당 SQL 연산자 및 함수로 변환되는 다른 DAX 함수 및 연산자와 달리 위의 관계는 다음과 같이 SQL 조인 조건자를 생성합니다.

    (Table1.Column1 = Table2.Column1 OR Table1.Column1 IS NULL AND Table2.Column1 IS NULL)
    

    그리고

    (Table1.Column2 = Table2.Column2 OR Table1.Column2 IS NULL AND Table2.Column2 IS NULL)
    
  • 조인 조건자는 복잡한 SQL 연산자 및 함수를 포함하는 것보다 훨씬 더 나은 쿼리 성능을 제공할 수 있습니다.

  • COMBINEVALUES 함수는 사용자가 적절한 구분 기호를 선택하여 입력 값의 고유한 조합이 고유한 출력 문자열을 생성하도록 하지만 가정이 참인지는 확인하지 않습니다. 예를 들어 사용자가 "| " 구분 기호로 선택하지만 Table1의 한 행에 Table1[Column1] = "| "Table2 [Column2] = " "있는 반면 Table2의 한 행에는 Table2[Column1] = " "Table2[Column2] = "| "두 개의 연결된 출력이 동일한 "|| "있습니다. 이는 두 행이 조인 작업에서 일치함을 나타내는 것처럼 보입니다. 두 테이블을 모두 가져오는 경우 함께 조인되지만 두 테이블이 모두 동일한 DirectQuery 원본에 있는 경우 두 행이 함께 조인되지 않습니다.

본보기

다음 DAX 쿼리는 다음과 같습니다.

EVALUATE
DISTINCT (
    SELECTCOLUMNS ( Date, "Month", COMBINEVALUES ( ", ", [MonthName], [CalendarYear] ) )
)

다음 단일 열 테이블을 반환합니다.

[월]
2020년 1월
2020년 2월
2020년 3월
2020년 4월
2020년 5월
2020년 6월
2020년 7월
2020년 8월
2020년 9월
2020년 10월
2020년 11월
2020년 12월
2021년 1월
2021년 1월
2021년 2월
2021년 3월
2021년 4월
2021년 5월
2021년 6월
2021년 7월
2021년 8월
2021년 9월
2021년 10월
2021년 11월
2021년 12월