Join us for an expert-led overview of the tools and concepts you'll need to pass exam PL-300. The first session starts on June 11th. See you there!
Get registeredPower BI is turning 10! Let’s celebrate together with dataviz contests, interactive sessions, and giveaways. Register now.
Is there a way to optimize the performance of below query
Sale from Current Inventory Balance NY =
VAR CurrentDate =
TODAY ()
VAR InitialValue = [Opening Bal]
VAR CurrentYear =
YEAR ( CurrentDate )
RETURN
SUMX (
FILTER (
ADDCOLUMNS (
CALENDAR ( TODAY (), DATE ( YEAR ( TODAY () ) + 1, 12, 31 ) ),
"DaysSinceStart", DATEDIFF ( CurrentDate, [Date], DAY ),
"DailyValueSub",
IF (
DATEDIFF ( CurrentDate, [Date], DAY ) < 'Day Range'[Day Range Value],
DIVIDE ( [Opening Bal], 'Day Range'[Day Range Value] )
)
),
[Date] >= CurrentDate
&& YEAR ( [Date] )
= YEAR ( TODAY () ) + 1
),
[DailyValueSub]
)
Solved! Go to Solution.
Hi @Antmkjr
Here are some suggestions to optimize your query:
Here’s an optimized version (1) of your query, you could try this:
SaleFromCurrentInventoryBalanceNY =
VAR CurrentDate = TODAY()
VAR InitialValue = [Opening Bal]
VAR CurrentYear = YEAR(CurrentDate)
VAR EndDate = DATE(CurrentYear + 1, 12, 31)
VAR DateRange = CALENDAR(CurrentDate, EndDate)
RETURN
SUMX(
FILTER(
ADDCOLUMNS(
DateRange,
"DaysSinceStart", DATEDIFF(CurrentDate, [Date], DAY),
"DailyValueSub",
IF(
DATEDIFF(CurrentDate, [Date], DAY) < 'Day Range'[Day Range Value],
DIVIDE(InitialValue, 'Day Range'[Day Range Value])
)
),
[Date] >= CurrentDate && YEAR([Date]) = CurrentYear + 1
),
[DailyValueSub]
)
Version 2:
SaleFromCurrentInventoryBalanceNY =
VAR CurrentDate = TODAY()
VAR InitialValue = [Opening Bal]
VAR CurrentYear = YEAR(CurrentDate)
VAR EndDate = DATE(CurrentYear + 1, 12, 31)
VAR DateRange = CALENDAR(CurrentDate, EndDate)
VAR FilteredDates =
FILTER(
DateRange,
[Date] >= CurrentDate && YEAR([Date]) = CurrentYear + 1
)
VAR CalculatedValues =
ADDCOLUMNS(
FilteredDates,
"DaysSinceStart", DATEDIFF(CurrentDate, [Date], DAY),
"DailyValueSub",
IF(
DATEDIFF(CurrentDate, [Date], DAY) < 'Day Range'[Day Range Value],
DIVIDE(InitialValue, 'Day Range'[Day Range Value])
)
)
RETURN
SUMX(
CalculatedValues,
[DailyValueSub]
)
Hope this helps!!
If this solved your problem, please accept it as a solution and a kudos!!
Best Regards,
Shahariar Hafiz
Hi @Antmkjr
Here are some suggestions to optimize your query:
Here’s an optimized version (1) of your query, you could try this:
SaleFromCurrentInventoryBalanceNY =
VAR CurrentDate = TODAY()
VAR InitialValue = [Opening Bal]
VAR CurrentYear = YEAR(CurrentDate)
VAR EndDate = DATE(CurrentYear + 1, 12, 31)
VAR DateRange = CALENDAR(CurrentDate, EndDate)
RETURN
SUMX(
FILTER(
ADDCOLUMNS(
DateRange,
"DaysSinceStart", DATEDIFF(CurrentDate, [Date], DAY),
"DailyValueSub",
IF(
DATEDIFF(CurrentDate, [Date], DAY) < 'Day Range'[Day Range Value],
DIVIDE(InitialValue, 'Day Range'[Day Range Value])
)
),
[Date] >= CurrentDate && YEAR([Date]) = CurrentYear + 1
),
[DailyValueSub]
)
Version 2:
SaleFromCurrentInventoryBalanceNY =
VAR CurrentDate = TODAY()
VAR InitialValue = [Opening Bal]
VAR CurrentYear = YEAR(CurrentDate)
VAR EndDate = DATE(CurrentYear + 1, 12, 31)
VAR DateRange = CALENDAR(CurrentDate, EndDate)
VAR FilteredDates =
FILTER(
DateRange,
[Date] >= CurrentDate && YEAR([Date]) = CurrentYear + 1
)
VAR CalculatedValues =
ADDCOLUMNS(
FilteredDates,
"DaysSinceStart", DATEDIFF(CurrentDate, [Date], DAY),
"DailyValueSub",
IF(
DATEDIFF(CurrentDate, [Date], DAY) < 'Day Range'[Day Range Value],
DIVIDE(InitialValue, 'Day Range'[Day Range Value])
)
)
RETURN
SUMX(
CalculatedValues,
[DailyValueSub]
)
Hope this helps!!
If this solved your problem, please accept it as a solution and a kudos!!
Best Regards,
Shahariar Hafiz
This is your chance to engage directly with the engineering team behind Fabric and Power BI. Share your experiences and shape the future.
Check out the June 2025 Power BI update to learn about new features.
User | Count |
---|---|
19 | |
14 | |
13 | |
11 | |
8 |