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

Join us at FabCon Atlanta from March 16 - 20, 2026, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM. Register now.

Reply
jguercio
Frequent Visitor

Calculated Column: Find value between dates from another table

Hi All,

 

Can someone help me write this so it does not produce this error?

"The expression contains columns from multiple tables, but only columns from a single table can be used in a True/False expression that is used as a table filter expression."

 

Intent:

I am trying to get a value from a fact table and put it in a calculated column of a summary table. The granularity of the fact table is multiple records in a day. The granularity of the summary table is monthly. Essentially, I need to know who is the primary worker between the two dates on the summary table. Sometimes the result has more than one worker, so I want the one that was most frequent during the time. The following works fine in Tabular Editor when I hard code the right-side variables of the CALCULATETABLE filters:

 

 

 

 

 

Primary Worker = 
VAR Table1 = 
CALCULATETABLE(
    SUMMARIZE(
        'FACT-Service',
        'FACT-Service'[Primary Worker on Contact Date],
        "CountPW", COUNT( 'FACT-Service'[Primary Worker on Contact Date] )
    ),
    'FACT-Service'[Bridge ID] = 'BH Monthly Billing Table'[Program-Client ID]
    && 'FACT-Service'[Contact Date] >= 'BH Monthly Billing Table'[Period Begin]
    && 'FACT-Service'[Contact Date] <= 'BH Monthly Billing Table'[Period End]
)

RETURN
      SELECTCOLUMNS(
      TOPN( 1, Table1, [CountPW]),
      "Worker", 'FACT-Service'[Primary Worker on Contact Date]
  )

 

 

 

 

 

 

1 ACCEPTED SOLUTION

I get the following error when I run the solution:
The column 'Monthly Billing Table[ProgramID-ID]' either doesn't exist or doesn't have a relationship to any table available in the current context.

 

However, this solution seems to work:

Primary Worker = 
var ProgClientID = 'BH Monthly Billing Table'[Program-Client ID]
var PD_Begin = 'BH Monthly Billing Table'[Period Begin]
var PD_End = 'BH Monthly Billing Table'[Period End]
VAR Table1 = 
CALCULATETABLE(
ADDCOLUMNS(
    SUMMARIZE(
        'FACT-Service',
        'FACT-Service'[Primary Worker on Contact Date],
        "CountPW", COUNT( 'FACT-Service'[Primary Worker on Contact Date] )
    ), "WorkerName",'FACT-Service'[Primary Worker on Contact Date] ),
    'FACT-Service'[Bridge ID] =ProgClientID
    && 'FACT-Service'[Contact Date] >= PD_Begin
    && 'FACT-Service'[Contact Date] <= PD_End
)

var W_name_row = TOPN(1,table1, [CountPW], DESC)

RETURN
MAXX(W_name_row, [WorkerName])

 I appreciate your speedy attempt, thank you.

View solution in original post

7 REPLIES 7
jguercio
Frequent Visitor

Here is a sample file of the issue. Thanks for your assistance:

PBI Sample File 

Create a relationship like below and rewrite the formula:

Vlianlmsft_0-1628672888503.png

Primary Worker = 
VAR Table1 = 
CALCULATETABLE(
    SUMMARIZE(
        'FACT-Service',
        'FACT-Service'[Primary Worker on Contact Date],
        "CountPW", COUNT( 'FACT-Service'[Primary Worker on Contact Date] )
    ),FILTER('FACT-Service',
    RELATED('Monthly Billing Table'[ProgramID-ID]) = 'FACT-Service'[Bridge ID]
    && 'FACT-Service'[Contact Date] >= RELATED('Monthly Billing Table'[Period Begin])
    && 'FACT-Service'[Contact Date] <= RELATED('Monthly Billing Table'[Period End]
)))

RETURN
      SELECTCOLUMNS(
      TOPN( 1, Table1, [CountPW]),
      "Worker", 'FACT-Service'[Primary Worker on Contact Date]
  )

Is this the result you want?

Vlianlmsft_1-1628672969944.png

 

 

I get the following error when I run the solution:
The column 'Monthly Billing Table[ProgramID-ID]' either doesn't exist or doesn't have a relationship to any table available in the current context.

 

However, this solution seems to work:

Primary Worker = 
var ProgClientID = 'BH Monthly Billing Table'[Program-Client ID]
var PD_Begin = 'BH Monthly Billing Table'[Period Begin]
var PD_End = 'BH Monthly Billing Table'[Period End]
VAR Table1 = 
CALCULATETABLE(
ADDCOLUMNS(
    SUMMARIZE(
        'FACT-Service',
        'FACT-Service'[Primary Worker on Contact Date],
        "CountPW", COUNT( 'FACT-Service'[Primary Worker on Contact Date] )
    ), "WorkerName",'FACT-Service'[Primary Worker on Contact Date] ),
    'FACT-Service'[Bridge ID] =ProgClientID
    && 'FACT-Service'[Contact Date] >= PD_Begin
    && 'FACT-Service'[Contact Date] <= PD_End
)

var W_name_row = TOPN(1,table1, [CountPW], DESC)

RETURN
MAXX(W_name_row, [WorkerName])

 I appreciate your speedy attempt, thank you.

V-lianl-msft
Community Support
Community Support

PaulDBrown
Community Champion
Community Champion

SELECTCOLUMNS returns a table which will return an error as you are seeing. You could try wrapping it in COUNTROWS and use the measure to filter the values in a visual where the outcome = 1

so...

 

 

Primary Worker = 
VAR Table1 = 
CALCULATETABLE(
    SUMMARIZE(
        'FACT-Service',
        'FACT-Service'[Primary Worker on Contact Date],
        "CountPW", COUNT( 'FACT-Service'[Primary Worker on Contact Date] )
    ),
    'FACT-Service'[Bridge ID] = 'BH Monthly Billing Table'[Program-Client ID]
    && 'FACT-Service'[Contact Date] >= 'BH Monthly Billing Table'[Period Begin]
    && 'FACT-Service'[Contact Date] <= 'BH Monthly Billing Table'[Period End]
)

RETURN
      COUNTROWS(
SELECTCOLUMNS(
      TOPN( 1, Table1, [CountPW]),
      "Worker", 'FACT-Service'[Primary Worker on Contact Date]
  )
)

 

 





Did I answer your question? Mark my post as a solution!
In doing so, you are also helping me. Thank you!

Proud to be a Super User!
Paul on Linkedin.






amitchandak
Super User
Super User

@jguercio ,Can you share sample data and sample output in table format? Or a sample pbix after removing sensitive data.

 

We can think of creating a column if that can work

refer 4 ways to copy data from one table to another
https://www.youtube.com/watch?v=Wu1mWxR23jU
https://www.youtube.com/watch?v=czNHt7UXIe8

Share with Power BI Enthusiasts: Full Power BI Video (20 Hours) YouTube
Microsoft Fabric Series 60+ Videos YouTube
Microsoft Fabric Hindi End to End YouTube

How do I share the sample .pbx file? I get an error that .pbx is not supported.

Helpful resources

Announcements
FabCon Global Hackathon Carousel

FabCon Global Hackathon

Join the Fabric FabCon Global Hackathon—running virtually through Nov 3. Open to all skill levels. $10,000 in prizes!

October Power BI Update Carousel

Power BI Monthly Update - October 2025

Check out the October 2025 Power BI update to learn about new features.

FabCon Atlanta 2026 carousel

FabCon Atlanta 2026

Join us at FabCon Atlanta, March 16-20, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM.