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
AjithPrasath
Resolver II
Resolver II

Dynamically Change the Database name in the Powerbi desktop

Hi All,

 

   I am trying to  change the database name dynamically in the powerbi from the powerbi rest api call. I created parameters for server and database name  and use that in the query . I am trying to update the database name dynamically from the rest api. But , I am getting the same data  for the database which I given as the default in the parameter name. This is the code where I am updating the datasource name from powerbi rest api. I need to change the database name whatever I am giving as the input. Please help me to resolve this 

// Create UpdateDatasourceRequest to update Azure SQL datasource credentials
UpdateDatasourceRequest req = new UpdateDatasourceRequest {
CredentialDetails = new CredentialDetails(
new BasicCredentials(SqlUserName, SqlUserPassword),
PrivacyLevel.Organizational,
EncryptedConnection.Encrypted)
};
// Execute Patch command to update Azure SQL datasource credentials
pbiClient.Gateways.UpdateDatasource((Guid)gatewayId, (Guid)datasourceId, req);

5 REPLIES 5
AjithPrasath
Resolver II
Resolver II

Hi @lbendlin ,
My requirement is we have multiple customers  and for each customer we have seperate database. So for each customer the report template will be same but we have to dynamically the change the database for each customer so that correct data will be displayed. For implementing this I used - parameters and given dynmaically the database name and server name in the sources. But while calling the report using powerbi rest api , even if I pass different datasource credential - it's still getting the same data for the database which I given as the current value.
Please help me to resolve this

 For implementing this I used - parameters and given dynmaically the database name and server name in the sources. 

You cannot do that.  Use a fixed server and database name for the base connection definition, and then swap out the database name in the custom SQL query.

Thanks for the reply. Can you elaborate on that swap out the database name in the custom sql query?

 

let Source = Sql.Database(server, database1, [Query="Select * from [database2].[schema].[table]"])

 

lbendlin
Super User
Super User

You can only change credentials, you cannot change the connection details.

 

Create a new connection or run a custom SQL that overrides the database name.

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.