COMBINEVALUES
gælder for:beregnet kolonneberegnet tabelMeasurevisualiseringsberegning
Joinforbinder to or flere tekststrenge til én tekststreng. Det primære formål med denne funktion er at understøtte relationer med flere kolonner i DirectQuery-modeller. Se bemærkninger for at få flere oplysninger.
Syntaks
COMBINEVALUES(<delimiter>, <expression>, <expression>[, <expression>]…)
Parametre
Udtryk | Definition |
---|---|
delimiter |
En separator, der skal bruges under sammenkædning. Skal være en konstant value. |
expression |
Et DAX udtryk, hvis value joinforbindes til en enkelt tekststreng. |
Returner value
En sammenkædet streng.
Bemærkninger
Funktionen COMBINEVALUES antager, men validerer not, at outputstrengene også er forskellige, når input values er forskellige. Når COMBINEVALUES bruges til at oprette beregnede kolonner for at oprette en relation, der joinforbinder flere kolonner fra to DirectQuery-tabeller, oprettes der en optimeret joinforbindelsesbetingelse ved forespørgsel time. if brugere f.eks. vil oprette en relation mellem Table1(Column1, Column2) and Table2(Column1, Column2), kan de oprette to beregnede kolonner, én i hver tabel, som:
Table1[CalcColumn] = COMBINEVALUES(",", Table1[Column1], Table1[Column2])
and
Table2[CalcColumn] = COMBINEVALUES(",", Table2[Column1], Table2[Column2])
And opretter derefter en relation mellem
Table1[CalcColumn]
andTable2[CalcColumn]
. I modsætning til andre DAX funktioner and operatorer, som bogstaveligt talt oversættes til de tilsvarende SQL-operatorer and funktioner, genererer ovenstående relation et PRÆdikat for SQL-joinforbindelse som:(Table1.Column1 = Table2.Column1 OR Table1.Column1 IS NULL AND Table2.Column1 IS NULL)
and
(Table1.Column2 = Table2.Column2 OR Table1.Column2 IS NULL AND Table2.Column2 IS NULL)
Prædikatet joinforbindelse kan potentielt levere meget bedre forespørgselsydeevne end en, der omfatter komplekse SQL-operatorer and funktioner.
Funktionen COMBINEVALUES er afhængig af, at brugerne vælger den relevante afgrænser for at sikre, at entydige kombinationer af input values producere særskilte outputstrenge, men den validerer not, at antagelsen er true. if brugere vælger f.eks.
"| "
som afgrænser, men én række i Table1 harTable1[Column1] = "| "
andTable2 [Column2] = " "
, mens én række i Table2 harTable2[Column1] = " "
andTable2[Column2] = "| "
, vil de to sammenkædede output være de samme"|| "
, hvilket synes at indikere, at de to rækker stemmer overens i joinhandlingen. De to rækker er not joinforbundet if begge tabeller er fra den samme DirectQuery-kilde, selvom de er joinforbundet if begge tabeller importeres.
Eksempel
Følgende DAX forespørgsel:
EVALUATE
DISTINCT (
SELECTCOLUMNS ( Date, "Month", COMBINEVALUES ( ", ", [MonthName], [CalendarYear] ) )
)
Returnerer følgende tabel med én kolonne:
[Month] |
---|
Januar 2020 |
Februar 2020 |
Marts 2020 |
April 2020 |
Maj 2020 |
Juni 2020 |
Juli 2020 |
August 2020 |
September, 2020 |
Oktober 2020 |
November, 2020 |
December 2020 |
Januar 2021 |
Januar 2021 |
Februar 2021 |
Marts 2021 |
April 2021 |
Maj 2021 |
Juni 2021 |
Juli 2021 |
August 2021 |
September, 2021 |
Oktober, 2021 |
November, 2021 |
December 2021 |