Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Register now to learn Fabric in free live sessions led by the best Microsoft experts. From Apr 16 to May 9, in English and Spanish.

Reply
Syndicate_Admin
Administrator
Administrator

Problema de columna calculado - Valor único

Hola

Estoy tratando de escribir una columna calculada basada en la siguiente lógica:

Si la descripción de la tabla de tipos es igual a "Primer día" o "Segundo día" ENTONCES cuántos minutos entre StartDateTime y EndDateTime de la tabla Hecho de llamada,

If Minutos entre StartDateTime y EndDateTime es mayor que 480 minutos y luego establece esto en 45 minutos

ELSE establece esto en número de minutos entre StartDateTime y EndDateTime

A continuación, he decretado una columna calculada con la siguiente fórula DAX:

TimeTaken =

IF('Type'[Descripción] EN {"Primer día","Segundo día"},
DATEDIFF('Call Fact'[StartDateTime], 'Call Fact'[EndDateTime], MINUTE),
IF(DATEDIFF('Call Fact'[StartDateTime], 'Call Fact'[EndDateTime], MINUTE) > 480, 45,
DATEDIFF('Call Fact'[StartDateTime], 'Call Analysis'[EndDateTime], MINUTE)))

Pero recibo el siguiente mensaje de error:

No se puede determinar un único valor para la columna 'Descripción' en la tabla 'Tipo'. Esto puede ocurrir cuando una fórmula de medida hace referencia a una columna que contiene muchos valores sin especificar una agregación como min, max, count o sum para obtener un único resultado.

¿Alguna idea?

1 ACCEPTED SOLUTION
Syndicate_Admin
Administrator
Administrator

No @AvPowerBI,

Primero deberá definir StartDateTime y EndDateTime en la tabla Type.

Por favor, compruebe la siguiente fórmula.

Column = 
var _start = LOOKUPVALUE('Call Fact'[StartDateTime],'Call Fact'[id],'Type'[id])
var _end = LOOKUPVALUE('Call Fact'[EndDateTime],'Call Fact'[id],'Type'[id])
var _diff = IF('Type'[Description] IN {"First Day","Second Day"},DATEDIFF(_start,_end,MINUTE))
return
IF(_diff>480,45,_diff)

4.PNG

5.PNG

Saludos

Jay

View solution in original post

2 REPLIES 2
Syndicate_Admin
Administrator
Administrator

No @AvPowerBI,

Primero deberá definir StartDateTime y EndDateTime en la tabla Type.

Por favor, compruebe la siguiente fórmula.

Column = 
var _start = LOOKUPVALUE('Call Fact'[StartDateTime],'Call Fact'[id],'Type'[id])
var _end = LOOKUPVALUE('Call Fact'[EndDateTime],'Call Fact'[id],'Type'[id])
var _diff = IF('Type'[Description] IN {"First Day","Second Day"},DATEDIFF(_start,_end,MINUTE))
return
IF(_diff>480,45,_diff)

4.PNG

5.PNG

Saludos

Jay

Syndicate_Admin
Administrator
Administrator

@AvPowerBI , No se puede utilizar la segunda tabla de esa forma. Dependiendo de la relación

IF(related('Type'[Description]) EN {"First Day","Second Day"},
DATEDIFF('Call Fact'[StartDateTime], 'Call Fact'[EndDateTime], MINUTE),
IF(DATEDIFF('Call Fact'[StartDateTime], 'Call Fact'[EndDateTime], MINUTE) > 480, 45,
DATEDIFF('Call Fact'[StartDateTime], 'Call Analysis'[EndDateTime], MINUTE)))

O

IF(maxx(relatedtable('Type'),[Descripción]) EN {"First Day","Second Day"},
DATEDIFF('Call Fact'[StartDateTime], 'Call Fact'[EndDateTime], MINUTE),
IF(DATEDIFF('Call Fact'[StartDateTime], 'Call Fact'[EndDateTime], MINUTE) > 480, 45,
DATEDIFF('Call Fact'[StartDateTime], 'Call Analysis'[EndDateTime], MINUTE)))


Además, consulte 4 maneras de copiar datos de una tabla a otra
https://www.youtube.com/watch?v=Wu1mWxR23jU
https://www.youtube.com/watch?v=czNHt7UXIe8

Helpful resources

Announcements
Microsoft Fabric Learn Together

Microsoft Fabric Learn Together

Covering the world! 9:00-10:30 AM Sydney, 4:00-5:30 PM CET (Paris/Berlin), 7:00-8:30 PM Mexico City

PBI_APRIL_CAROUSEL1

Power BI Monthly Update - April 2024

Check out the April 2024 Power BI update to learn about new features.

April Fabric Community Update

Fabric Community Update - April 2024

Find out what's new and trending in the Fabric Community.

Top Solution Authors