Migrate to Innovate Summit:
Learn how migrating and modernizing to Azure can boost your business's performance, resilience, and security, enabling you to fully embrace AI.Register now
This browser is no longer supported.
Upgrade to Microsoft Edge to take advantage of the latest features, security updates, and technical support.
This article uses the Azure Az PowerShell module, which is the recommended PowerShell module for interacting with Azure. To get started with the Az PowerShell module, see Install Azure PowerShell. To learn how to migrate to the Az PowerShell module, see Migrate Azure PowerShell from AzureRM to Az.
Use Azure Cloud Shell
Azure hosts Azure Cloud Shell, an interactive shell environment that you can use through your browser. You can use either Bash or PowerShell with Cloud Shell to work with Azure services. You can use the Cloud Shell preinstalled commands to run the code in this article, without having to install anything on your local environment.
To start Azure Cloud Shell:
Option
Example/Link
Select Try It in the upper-right corner of a code block. Selecting Try It doesn't automatically copy the code to Cloud Shell.
Go to https://shell.azure.com, or select the Launch Cloud Shell button to open Cloud Shell in your browser.
Select the Cloud Shell button on the menu bar at the upper right in the Azure portal.
To run the code in this article in Azure Cloud Shell:
Start Cloud Shell.
Select the Copy button on a code block to copy the code.
Paste the code into the Cloud Shell session by selecting Ctrl+Shift+V on Windows and Linux, or by selecting Cmd+Shift+V on macOS.
Select Enter to run the code.
If you choose to install and use PowerShell locally, this tutorial requires Az PowerShell 1.4.0 or later. If you need to upgrade, see Install Azure PowerShell module. If you are running PowerShell locally, you also need to run Connect-AzAccount to create a connection with Azure.
Sample script
PowerShell
# Connect-AzAccount# The SubscriptionId in which to create these objects$SubscriptionId = ''# Set the resource group name and location for your server$resourceGroupName = "myResourceGroup-$(Get-Random)"$location = "westeurope"# Set an admin login and password for your server$adminSqlLogin = "SqlAdmin"$password = "ChangeYourAdminPassword1"# Set server name - the logical server name has to be unique in the system$serverName = "server-$(Get-Random)"# The sample database name$databaseName = "myImportedDatabase"# The storage account name and storage container name$storageAccountName = "sqlimport$(Get-Random)"$storageContainerName = "importcontainer$(Get-Random)"# BACPAC file name$bacpacFilename = "sample.bacpac"# The ip address range that you want to allow to access your server$startip = "0.0.0.0"$endip = "0.0.0.0"# Set subscription Set-AzContext -SubscriptionId$subscriptionId# Create a resource group$resourcegroup = New-AzResourceGroup -Name$resourceGroupName -Location$location# Create a storage account $storageAccount = New-AzStorageAccount -ResourceGroupName$resourceGroupName `
-Name$storageAccountName `
-Location$location `
-SkuName"Standard_LRS"# Create a storage container $storageContainer = New-AzStorageContainer -Name$storageContainerName `
-Context $(New-AzStorageContext -StorageAccountName$storageAccountName `
-StorageAccountKey $(Get-AzStorageAccountKey -ResourceGroupName$resourceGroupName -Name$storageAccountName).Value[0])
# Download sample database from Github
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12 #required by GithubInvoke-WebRequest -Uri"https://github.com/Microsoft/sql-server-samples/releases/download/wide-world-importers-v1.0/WideWorldImporters-Standard.bacpac" -OutFile$bacpacfilename# Upload sample database into storage containerSet-AzStorageBlobContent -Container$storagecontainername `
-File$bacpacFilename `
-Context $(New-AzStorageContext -StorageAccountName$storageAccountName `
-StorageAccountKey $(Get-AzStorageAccountKey -ResourceGroupName$resourceGroupName -Name$storageAccountName).Value[0])
# Create a new server with a system wide unique server name$server = New-AzSqlServer -ResourceGroupName$resourceGroupName `
-ServerName$serverName `
-Location$location `
-SqlAdministratorCredentials $(New-Object -TypeName System.Management.Automation.PSCredential -ArgumentList$adminSqlLogin, $(ConvertTo-SecureString -String$password -AsPlainText -Force))
# Create a server firewall rule that allows access from the specified IP range$serverFirewallRule = New-AzSqlServerFirewallRule -ResourceGroupName$resourceGroupName `
-ServerName$serverName `
-FirewallRuleName"AllowedIPs" -StartIpAddress$startIp -EndIpAddress$endIp# Import bacpac to database with an S3 performance level$importRequest = New-AzSqlDatabaseImport -ResourceGroupName$resourceGroupName `
-ServerName$serverName `
-DatabaseName$databaseName `
-DatabaseMaxSizeBytes100GB `
-StorageKeyType"StorageAccessKey" `
-StorageKey $(Get-AzStorageAccountKey -ResourceGroupName$resourceGroupName -StorageAccountName$storageAccountName).Value[0] `
-StorageUri"https://$storageaccountname.blob.core.windows.net/$storageContainerName/$bacpacFilename" `
-Edition"Standard" `
-ServiceObjectiveName"S3" `
-AdministratorLogin"$adminSqlLogin" `
-AdministratorLoginPassword $(ConvertTo-SecureString -String$password -AsPlainText -Force)
# Check import status and wait for the import to complete$importStatus = Get-AzSqlDatabaseImportExportStatus -OperationStatusLink$importRequest.OperationStatusLink
[Console]::Write("Importing")
while ($importStatus.Status -eq"InProgress")
{
$importStatus = Get-AzSqlDatabaseImportExportStatus -OperationStatusLink$importRequest.OperationStatusLink
[Console]::Write(".")
Start-Sleep -s10
}
[Console]::WriteLine("")
$importStatus# Scale down to S0 after import is completeSet-AzSqlDatabase -ResourceGroupName$resourceGroupName `
-ServerName$serverName `
-DatabaseName$databaseName `
-Edition"Standard" `
-RequestedServiceObjectiveName"S0"# Clean up deployment # Remove-AzResourceGroup -ResourceGroupName $resourceGroupName
Clean up deployment
Use the following command to remove the resource group and all resources associated with it.
Administer an SQL Server database infrastructure for cloud, on-premises and hybrid relational databases using the Microsoft PaaS relational database offerings.