Power BI is turning 10! Tune in for a special live episode on July 24 with behind-the-scenes stories, product evolution highlights, and a sneak peek at what’s in store for the future.
Save the dateEnhance your career with this limited time 50% discount on Fabric and Power BI exams. Ends August 31st. Request your voucher.
I received the DECLARE error message stating I can't use declare in a Direct Query. I found out in this forum that a user defined function (UDF) is necessary to make this work: https://community.powerbi.com/t5/Desktop/Why-is-DECLARE-not-supported-Error/td-p/40983
I then found out from the error message that I can't have dynamic SQL in a UDF.
"Invalid use of a side-effecting operator 'EXECUTE STRING' within a function."
Are there any other options for getting my query to work in a direct query in Power BI? My query is below:
DECLARE @SQL as VARCHAR(MAX) DECLARE @Columns AS VARCHAR(MAX) SELECT @Columns = COALESCE(@Columns + ', ','')+QUOTENAME([MonthYear]) FROM( SELECT distinct cast([MonthName] as varchar) + ' ''' + right(cast([Year] as varchar),2) AS MonthYear, [Year],[Month] FROM gpo.dbo.DateDimension A WHERE [Date] between getdate()-365 AND dateadd(month,-1,getdate())) A order by [Year],[Month] SET @SQL = ' WITH PivotData AS ( SELECT distinct A.[Client Designated Loc Nm] as Client, sum(A.TotalInvoice) as [Total Admin Fee], cast([MonthName] as varchar) + '' '''''' + right(cast([Year] as varchar),2) AS MonthYear FROM GPO.DBO.SALES A INNER JOIN GPO.DBO.datedimension B ON A.InvoiceDate=B.[Date] INNER JOIN RXSS.DBO.SupplierContractNbrs C ON A.SupplierID=C.SupplierID WHERE A.[Status] = ''A'' and C.ActiveReporting = 1 AND B.[Date] >= getdate()-365 GROUP BY A.SupplierID, A.[Client Designated Loc Nm], A.InvoiceDate, B.[MonthName], B.[Year], B.[MonthYear] ) SELECT * FROM (SELECT Client, ' + @Columns + ' FROM PivotData PIVOT ( sum([Total Admin Fee]) FOR [MonthYear] IN ( ' + @Columns + ' ) ) AS pvt ) D ' EXEC (@SQL)
Hi,
Have someone has a workarround for this issue. I am also struggling with this. Thank you in advance
@Anonymous wrote:
I received the DECLARE error message stating I can't use declare in a Direct Query. I found out in this forum that a user defined function (UDF) is necessary to make this work: https://community.powerbi.com/t5/Desktop/Why-is-DECLARE-not-supported-Error/td-p/40983
I then found out from the error message that I can't have dynamic SQL in a UDF.
"Invalid use of a side-effecting operator 'EXECUTE STRING' within a function."
Are there any other options for getting my query to work in a direct query in Power BI? My query is below:
May I know why dynamical PIVOT in your case? What is the final goal?
Hi @Anonymous
What about calling the sp_executeSQL proc and passing your dynamic query via that?
Worked for me using Direct Query
Check out the July 2025 Power BI update to learn about new features.
This is your chance to engage directly with the engineering team behind Fabric and Power BI. Share your experiences and shape the future.
User | Count |
---|---|
68 | |
64 | |
52 | |
39 | |
26 |
User | Count |
---|---|
80 | |
57 | |
45 | |
44 | |
35 |