gpt4 book ai didi

sql-server - 由于扇区大小不同错误,从 Azure Blob 存储恢复数据库失败

转载 作者:行者123 更新时间:2023-12-02 06:48:29 25 4
gpt4 key购买 nike

我正在尝试将 SQL Server 数据库从 AWS SQL Server 导入到 Azure SQL Server。以下是我在导入过程中执行的步骤:

  1. 将数据库从 AWS SQL Server 备份到 AWS S3 存储桶。
  2. 将 .bacpac 文件从 S3 存储桶复制到本地文件路径。
  3. 将 .bacpac 文件从本地文件路径上传到 Azure Blob 存储。

上传过程结束后,当我将 .bacpac 文件从 Azure Blob 存储恢复到 Azure SQL Server 时,出现以下异常。

*无法使用备份文件'https://sqlmigrateassistant.blob.core.windows.net/sql2005backup/demodatabase.bacpac ' 因为它最初的格式化扇区大小为 512,现在位于扇区大小为 65536 的设备上。RESTORE FILELIST 异常终止*

在上面的步骤 2 之后,我还尝试将 .bacpac 文件从本地文件路径手动从 SQL Server Management studio(SSMS) 导入到 Azure SQL Server。当时我收到以下异常。

*文件包含损坏的数据。 (Microsoft.Data.Tools.Schema.Sql)*

任何人都可以提供有关如何将数据库还原到 Azure SQL Server 的任何信息吗?

非常感谢任何信息。

最佳答案

您必须使用 URL 恢复数据库并指定 block 大小 512..

RESTORE DATABASE [AdventureWorks2012] FROM  URL = N'your bacpac path'
WITH CREDENTIAL = N'My_Credential'
, FILE = 1, NOUNLOAD, STATS = 5,BLOCKSIZE= 512;

失败原因已解释如下:Database restore failure when restoring from URL并且上下文也适用于您的场景

When backing up to URL, SQL Server uses the 64K block size by default because the sector size presented by Azure blob storage is 64K. Therefore, regular scheduled backups to URL created by Managed Backup have the same block size as the media sector size, and this issue does not occur. But when a backup created on a local disk with 4K sector size is copied to the storage account, and then an attempt is made to restore from it, SQL Server blocks it with the above error message

关于sql-server - 由于扇区大小不同错误,从 Azure Blob 存储恢复数据库失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42902827/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com