Events
Mar 31, 11 PM - Apr 2, 11 PM
The ultimate SQL, Power BI, Fabric, and AI community-led event. March 31 - April 2. Use code MSCUST for a $150 discount. Prices go up Feb 11th.
Register todayThis browser is no longer supported.
Upgrade to Microsoft Edge to take advantage of the latest features, security updates, and technical support.
Applies to: SQL Server - Linux
This article shows how to use SQL Server Management Studio (SSMS) and SqlPackage to export and import a database on SQL Server on Linux. SSMS and SqlPackage.exe are Windows applications, so use this technique when you have a Windows machine that can connect to a remote SQL Server instance on Linux.
You should always install and use the most recent version of SSMS as described in Use SQL Server Management Studio on Windows to manage SQL Server on Linux.
For information about migrating a database from one SQL Server instance to another, see Migrate a SQL Server database from Windows to Linux using backup and restore.
Start SSMS by typing Microsoft SQL Server Management Studio in the Windows search box, and then select the desktop app.
Connect to your source database in Object Explorer. The source database can be in Microsoft SQL Server running on-premises or in the cloud, on Linux, Windows, or Docker and Azure SQL Database or Azure Synapse Analytics.
Right-click the source database in the Object Explorer, point to Tasks, and select Export Data-Tier Application...
In the export wizard, select Next, and then on the Settings tab, configure the export to save the BACPAC file to either a local disk location or to an Azure blob.
By default, all objects in the database are exported. Select the Advanced tab and choose the database objects that you wish to export.
Select Next and then select Finish.
The .bacpac
file is successfully created at the location you chose, and you're ready to import it into a target database.
Start SSMS by typing Microsoft SQL Server Management Studio in the Windows search box, and then select the desktop app.
Connect to your target server in Object Explorer. The target server can be Microsoft SQL Server running on-premises or in the cloud, on Linux, Windows, or Docker and Azure SQL Database or Azure Synapse Analytics.
Right-click the Databases folder in the Object Explorer and select Import Data-tier Application...
To create the database in your target server, specify a BACPAC file from your local disk, or select the Azure storage account and container to which you uploaded your BACPAC file.
Provide the new database name for the database. If you're importing a database on Azure SQL Database, set the Edition of Microsoft Azure SQL Database (service tier), Maximum database size, and Service Objective (performance level).
Select Next and then select Finish to import the BACPAC file into a new database in your target server.
The .bacpac
file is imported to create a new database in the target server you specified.
It's also possible to use the SQL Server Data Tools (SSDT) command-line tool, SqlPackage, to export and import BACPAC files.
The following example command exports a BACPAC file:
SqlPackage.exe /a:Export /ssn:tcp:<your_server> /sdn:<your_database> /su:<username> /sp:<password> /tf:<path_to_bacpac>
Use the following command to import database schema and user data from a .bacpac
file:
SqlPackage.exe /a:Import /tsn:tcp:<your_server> /tdn:<your_database> /tu:<username> /tp:<password> /sf:<path_to_bacpac>
Events
Mar 31, 11 PM - Apr 2, 11 PM
The ultimate SQL, Power BI, Fabric, and AI community-led event. March 31 - April 2. Use code MSCUST for a $150 discount. Prices go up Feb 11th.
Register todayTraining
Module
Deploy SQL Server on Linux - Training
Learn about prerequisites to run SQL Server on Linux and the steps to install SQL Server on Linux. Also, learn about installing command-line tools.
Certification
Microsoft Certified: Azure Database Administrator Associate - Certifications
Administer an SQL Server database infrastructure for cloud, on-premises and hybrid relational databases using the Microsoft PaaS relational database offerings.