In Power Automate, when you want to connect to a SQL Server and if you have a On-Promise Gateway, then you cannot use the command “Execute a SQL Query” because it will say it’s not currently supported.
There is a workaround with “Transform data using Power Query” (ATTENTION: you cannot load it from a flow from a Solution… you’ll have to go to your Flows and edit the flow from there):
data:image/s3,"s3://crabby-images/1054a/1054ab9b44d9ad12655bb59f920c4f252f65a283" alt=""
Let’s say we have 3 tables: ITEM_CATALOG, CATALOG and CURRENCY. We want to join them and filter them based on a variable found previously in our flow.
First, we can define our where
. Here I have several values that I want to test using a IN
:
data:image/s3,"s3://crabby-images/f417f/f417f11a6bf648fd1fe6905cf83a11fb4654ffe3" alt=""
I create a string with my different values separated by a coma.
Next, we can open the Power Query editor:
data:image/s3,"s3://crabby-images/c06cd/c06cdcdd2b3e7790fccc4a8b4445d6cca9a47fb9" alt=""
In the interface, we choose the 3 tables we need to merge and we add a parameter called “where”:
data:image/s3,"s3://crabby-images/1833b/1833bf3ef9c9367b56058107cc5dea596cf6f5b8" alt=""
We rename it to “where” and leave the default settings:
data:image/s3,"s3://crabby-images/c4e7a/c4e7a27fc9c488a688bc9c7c4c02767b8bf0c212" alt=""
Then we use the “Advance Editor”:
data:image/s3,"s3://crabby-images/f3f06/f3f06f4bf69818f587a0440406af0a3ee1abaf25" alt=""
And we wrote the below:
let
where = Text.Split( "@{variables('where')}" , ",")
in
where
It means we want to split the variable “where” coming from the flow, based on the coma separator:
data:image/s3,"s3://crabby-images/7af5b/7af5bb5b0f9491434b2957710aa735e2c01748c2" alt=""
We can now merge the tables and add a filter:
data:image/s3,"s3://crabby-images/52f08/52f08f18e0d629519782a98c0c92dffc49ac8c5b" alt=""
And when the step to filter is here, we select “in” and our query:
data:image/s3,"s3://crabby-images/469d9/469d941c7cf564d14267e187bb94c39bcb3ac021" alt=""
Last step is to “Enable Load” to make sure this is what the operation will return to our flow:
data:image/s3,"s3://crabby-images/602ae/602ae610405815e352e185ba2b4a8f6453e64366" alt=""
You can run it to test and see if it works.
Then, to get the output from it, we’ll use a “Parse JSON”… The schema is probably something like:
{
"type": "object",
"properties": {
"resultType": {
"type": "string"
},
"value": {
"type": "array",
"items": {
"type": "object",
"properties": {
"COLUMN_A": {
"type": "string"
},
"COLUMN_B": {
"type": "integer"
},
"COLUMN_C": {
"type": "string"
}
},
"required": [
"COLUMN_A",
"COLUMN_B",
"COLUMN_C"
]
}
}
}
}
You may need to make several tries in order to find the correct schema. You can also use the “Generate from sample” by pasting the data from the previous step:
data:image/s3,"s3://crabby-images/8fff1/8fff13b6d171ea64ad946105274beba38e811f8a" alt=""
We use “value” in the loop:
data:image/s3,"s3://crabby-images/9188b/9188b2d1103e59e0cf8353ed8fc0f453b0e2ea30" alt=""
And then we can access our columns:
data:image/s3,"s3://crabby-images/c8e4f/c8e4f322dfa4a1c71786b9208eba564efe0d9be1" alt=""