You will probably find that the Data-tier Applications BACPAC format will provide you with the most convenient solution. You can use Export to produce a file that contains both the database schema and data. Import will create a new database that is populated with data based on that file.
In contrast to the Backup and Restore operations, Export and Import do not require access to the database server's file system.
You can work with BACPAC files using SQL Server Management Studio or via the API in .Net, Powershell, MSBuild etc.
data:image/s3,"s3://crabby-images/77ad0/77ad01e3f2355059a97f4c152c2a2b093d924e30" alt="Export Data-tier Application Dialog"
Note that there are issues using this method to Export and then Import from and to Amazon RDS. As a new database is created on RDS, the following two objects are created within it.
- A User with membership in the db_owner role.
- The rds_deny_backups_trigger Trigger
data:image/s3,"s3://crabby-images/233d7/233d72f168e567b457bf722a25565997fd6f3e02" alt="The rds_deny_backups_trigger Trigger"
During the import, there will be a conflict between the objects included in the BACPAC file and the ones that are added automatically by RDS. These objects are both present in the BACPAC file and automatically created by RDS as the new database is created.
If you have a non-RDS instance of SQL Server handy, then you can Import the BACPAC to that instance, drop the objects above and then export the database to create a new BACPAC file. This one will not have any conflicts when you restore it to an RDS instance.
Otherwise, it is possible to work around this issue using the following steps.
- Edit the model.xml file within the BACPAC file (BACPACs are just zip files).
- Remove elements with the following values in their Type attributes that are related to the objects listed above (those that are automatically added by RDS).
- SqlRoleMembership
- SqlPermissionStatement
- SqlLogin
- SqlUser
- SqlDatabaseDdlTrigger
- Generate a checksum for the modified version of the model.xml file using one of the ComputeHash methods on the SHA256 class.
- Use the BitConverter.ToString() method to convert the hash to a hexadecimal string (you will need to remove the separators).
- Replace the existing hash in the Checksum element in the origin.xml file (also contained within the BACPAC file) with the new one.
- Create a new BACPAC file by zipping the contents of the original with both the model.xml and origin.xml files replaced with the new versions. Do NOT use System.IO.Compression.ZipFile for this purpose as there seems to be some conflict with the zip file that is produced - the data is not included in the import. I used 7Zip without any problems.
- Import the new BACPAC file and you should not have any conflicts with the objects that are automatically generated by RDS.
Note: There is another, related problem with importing a BacPac to RDS using SQL Server Management Studio which I explain here.