Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
You can automatically deploy your database updates to Azure Database for MySQL Flexible Server after every successful build with Azure Pipelines. You can use the Azure CLI task to update the database with either a SQL file or an inline SQL script. You can run this task on cross-platform agents running on Linux, macOS, or Windows operating systems.
Prerequisites
- An Azure account. If you don't have one, get a free trial. 
- Azure Resource Manager service connection to your Azure account 
- Microsoft hosted agents have Azure CLI preinstalled. However, if you use private agents, install Azure CLI on the computers that run the build and release agent. If an agent is already running on the machine where you install Azure CLI, restart the agent to update all relevant stage variables. 
This quickstart uses the resources created in either of these guides as a starting point:
- Create an Azure Database for MySQL Flexible Server instance by using the Quickstart: Create an instance of Azure Database for MySQL with the Azure portal or Quickstart: Create an instance of Azure Database for MySQL - Flexible Server by using the Azure CLI.
Use SQL file
The following example shows how to pass database arguments and run the execute command.
- task: AzureCLI@2
  displayName: Azure CLI
  inputs:
    azureSubscription: <Name of the Azure Resource Manager service connection>
    scriptLocation: inlineScript
    arguments:
      -SERVERNAME mydemoserver `
      -DBNAME pollsdb `
      -DBUSER pollsdbuser`
      -DBPASSWORD pollsdbpassword
    inlineScript: |
      az login --allow-no-subscription
      az mysql flexible-server execute --name $(SERVERNAME) \
      --admin-user $(DBUSER) --admin-password '$(DBPASSWORD)' \
      --database-name $(DBNAME) \
      --file-path /code/sql/db-schema-update.sql
Use inline SQL script
The following example shows how to run an inline SQL script using the execute command.
- task: AzureCLI@2
  displayName: Azure CLI
  inputs:
    azureSubscription: <Name of the Azure Resource Manager service connection>
    scriptLocation: inlineScript
    arguments:
      -SERVERNAME mydemoserver `
      -DBNAME pollsdb `
      -DBUSER pollsdbuser`
      -DBPASSWORD pollsdbpassword
      -INLINESCRIPT
    inlineScript: |
      az login --allow-no-subscription
      az mysql flexible-server execute --name $(SERVERNAME) \
      --admin-user $(DBUSER) --admin-password '$(DBPASSWORD)' \
      --database-name $(DBNAME) \
      --query-text "UPDATE items SET items.retail = items.retail * 0.9 WHERE items.id =100;"
Task inputs
You can see the full list of all the task inputs when using Azure CLI task with Azure Pipelines.
| Parameter | Description | 
|---|---|
| azureSubscription | (Required) Provide the Azure Resource Manager subscription for the deployment. This parameter is shown only when the selected task version is 0.* as Azure CLI task v1.0 supports only Azure Resource Manager subscriptions. | 
| scriptType | (Required) Provide the type of script. Supported scripts are PowerShell, PowerShell Core, Bat, Shell, and script. When running on a Linux agent, select one of the following: bashorpscore. When running Windows agent, select one of the following:batch,psandpscore. | 
| scriptLocation | (Required) Provide the path to script, for example real file path or use Inline scriptwhen providing the scripts inline. The default value isscriptPath. | 
| scriptPath | (Required) Fully qualified path of the script(.ps1 or .bat or .cmd when using Windows-based agent else .ps1 or.sh when using linux-based agent) or a path relative to the default working directory. | 
| inlineScript | (Required) You can write your scripts inline here. When using Windows agent, use PowerShell or PowerShell Core or batch scripting whereas use PowerShell Core or shell scripting when using Linux-based agents. For batch files use the prefix "call" before every Azure command. You can also pass predefined and custom variables to this script using arguments. Example for PowerShell/PowerShellCore/shell:  az --version az account showExample for batch:  call az --version call az account show. | 
| arguments | (Optional) Provide all the arguments passed to the script. For examples -SERVERNAME mydemoserver. | 
| powerShellErrorActionPreference | (Optional) Prepends the line $ErrorActionPreference = 'VALUE' at the top of your PowerShell/PowerShell Core script. The default value is stop. Supported values are stop, continue, and silentlyContinue. | 
| addSpnToEnvironment | (Optional) Adds service principal ID and key of the Azure endpoint you chose to the script's execution environment. You can use these variables: $env:servicePrincipalId, $env:servicePrincipalKey and $env:tenantId in your script. This is honored only when the Azure endpoint has Service Principal authentication scheme. The default value is false. | 
| useGlobalConfig | (Optional) If this is false, this task will use its own separate Azure CLI configuration directoryAzure CLI configuration directory. This can be used to run Azure CLI tasks in parallel releases" Default value: false | 
| workingDirectory | (Optional) Current working directory where the script is run. Empty is the root of the repo (build) or artifacts (release), which is $(System.DefaultWorkingDirectory). | 
| failOnStandardError | (Optional) If this is true, this task fails when any errors are written to the StandardError stream. Unselect the checkbox to ignore standard errors and rely on exit codes to determine the status. The default value is false. | 
| powerShellIgnoreLASTEXITCODE | (Optional) If this is false, the line if ((Test-Path -LiteralPath variable:\LASTEXITCODE)) { exit $LASTEXITCODE }is appended to the end of your script. This value causes the last exit code from an external command to be propagated as the exit code of PowerShell. Otherwise the line isn't appended to the end of your script. The default value is false. | 
| If you're having issues with CLI Task, see how to troubleshoot Build and Release. |