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

July 7 - July 17 | Round 2 of the Power BI Dataviz World Championships. Don't miss your chance! Learn more

Reply
schdef
Frequent Visitor

Parameterized SQL Query with query folding

I have a table loaded to my data model containing IDs. I want use these IDs to filter another query connecting to a SQL table. I tried to merge the SQL query with the ID table but then the query does not get folded as it should (which is a problem as my SQL source has millions of rows). Any practice that makes sense thinking of performance in particular... Thxs much!!

1 ACCEPTED SOLUTION
Anonymous
Not applicable

Hi @schdef,

 

You can tansfrom your data to text, then use it into sql query.

 

Sample: Convert region records to text.

 

let
    Source=data,
    Region = "'"&Text.Combine(List.Distinct(Source[Region]),"','")&"'"
in
    Region

 

Capture.PNGCapture2.PNG

 

Insert into sql query:

 

let
Source = Sql.Database("xxxxx", "xxxxx", [Query="SELECT * FROM Sales WHERE Region In ("&Region&")"])
in
Source

 

 

Regards,

Xiaoxin Sheng

View solution in original post

7 REPLIES 7
Anonymous
Not applicable

Hi @schdef,

 

You can tansfrom your data to text, then use it into sql query.

 

Sample: Convert region records to text.

 

let
    Source=data,
    Region = "'"&Text.Combine(List.Distinct(Source[Region]),"','")&"'"
in
    Region

 

Capture.PNGCapture2.PNG

 

Insert into sql query:

 

let
Source = Sql.Database("xxxxx", "xxxxx", [Query="SELECT * FROM Sales WHERE Region In ("&Region&")"])
in
Source

 

 

Regards,

Xiaoxin Sheng

Anonymous
Not applicable

How would you do this for more than 1000 items in a list?

I am trying to send a list back to Oracle and there is a 1000 item limit in the where clause.

If anyone has any ideas about this or has gotten around it in any way please let me know.

I am very new to power query and welcome all feedback.

OR the requests together

 

where x in (,,,,,)

or x in (,,,,,)

or x in (,,,,,)

 

etc.

I am working in Excel Power Pivot, my parameter list is generated from a table in the worksheet. The list generates well, and it displays correctly in the Query that is supposed to go out to SQL. Everything looks good, except, I am running into  a Formula.Firewall error message complaining that my step 'Source' references other queries and I need to rebuild it.

 

For months, I have been trying to figure out a way to fold dynamic parameters back to SQL. This is the closest I have gotten. I can see how this should work. I can't get around the error message though.

 

Is there something I need to be aware of when connecting to the database? Has something changed in the software that prevents this from folding back as intended? Are there better ways today to accomplish this task?

Anonymous
Not applicable

Even i have same error refelecting ? I couldnt find solution for that . Is there anyother way to do it ?

Anonymous
Not applicable

Thanks Xiaoxin! Was hoping to get this adressed with query folding and applying filters dynamically but your solution works as well.

Helpful resources

Announcements
FabCon and SQLCon Barcelona 2026

FabCon & SQLCon – Barcelona 2026

Join us in Barcelona for FabCon and SQLCon, the Fabric, Power BI, SQL, and AI community event. Save €200 with code FABCMTY200.

60 days of Data Days Carousel

Data Days 2026

Join Fabric Data Days 2026: 60 days of free live/on-demand sessions, challenges, study groups, and certification opportunities.

Power BI DataViz World Championships carousel

Power BI DataViz World Championships - June 2026

A new Power BI DataViz World Championship is coming this June! Don't miss out on submitting your entry.