gpt4 book ai didi

sql-server - 将 sp1 应用于 SQL Server 2014 后 RESTORE HEADERONLY 错误 3013

转载 作者:行者123 更新时间:2023-12-05 00:25:15 25 4
gpt4 key购买 nike

我最近将 SP1 应用到 SQL Server 2014,完成并除尘,没问题。几周后,当尝试使用我的一个存储过程从网络的 bak 文件恢复其中一个数据库时,抛出以下错误消息:

Error RESTORE HEADERONLY is terminating abnormally. Error 3013.

在存储过程中,我有以下两行代码从 bak 文件中获取数据库名称。

SET @strCheck = N'RESTORE HEADERONLY FROM DISK ='''+@backupFile+'''';

INSERT INTO #headerOnly EXEC(@strCheck);

经过一整天的摸索,我意识到 SQL Server 2014 sp1 已将 3 个新列添加到 Restore HeaderOnly 的输出中。代码中的临时表是在以前版本的 SQL Server SQL Server 2014 上创建的,没有最后三列,因此插入失败,错误为 3013。

SQL Server 2014 sp1 中的新列有以下 3 个:

KeyAlgorithm nvarchar(32); 
EncryptorThumbprint varbinary(20);
EncryptorType nvarchar(32);

最佳答案

我们有一个 Windows C/S 应用程序,可以在其中导出、导入和复制数据库。为了测试 SQL Server 2014,我们从 SQL Server 2008 导入了一些数据库,并在前一段时间用 2014 做了一些(成功的)测试。
现在我们已经安装了 SP1,但也遇到了其他错误消息的问题(例如“无法打开备份设备”)。然后,我也浪费了一整天的时间,直到找到信息,即 SP1 添加了三个新专栏(不幸的是,在我找到这篇文章之前)。

所以..我必须将 SP 中的三个新字段添加到 restoreheader 的定义中:

CREATE TABLE #restoreheader(
BackupName nvarchar(128)
, BackupDescription nvarchar(255)
, BackupType smallint
, ExpirationDate datetime
, Compressed tinyint
, Position smallint
, DeviceType tinyint
, UserName nvarchar(128)
, ServerName nvarchar(128)
, DatabaseName nvarchar(128)
, DatabaseVersion int
, DatabaseCreationDate datetime
, BackupSize numeric(20,0)
, FirstLSN numeric(25,0)
, LastLSN numeric(25,0)
, CheckpointLSN numeric(25,0)
, DatabaseBackupLSN numeric(25,0)
, BackupStartDate datetime
, BackupFinishDate datetime
, SortOrder smallint
, [CodePage] smallint
, UnicodeLocaleId int
, UnicodeComparisonStyle int
, CompatibilityLevel tinyint
, SoftwareVendorId int
, SoftwareVersionMajor int
, SoftwareVersionMinor int
, SoftwareVersionBuild int
, MachineName nvarchar(128)
, Flags int
, BindingID uniqueidentifier
, RecoveryForkID uniqueidentifier
, Collation nvarchar(128)
, FamilyGUID uniqueidentifier
, HasBulkLoggedData bit
, IsSnapshot bit
, IsReadOnly bit
, IsSingleUser bit
, HasBackupChecksums bit
, IsDamaged bit
, BeginsLogChain bit
, HasIncompleteMetaData bit
, IsForceOffline bit
, IsCopyOnly bit
, FirstRecoveryForkID uniqueidentifier
, ForkPointLSN numeric(25,0) NULL
, RecoveryModel nvarchar(60)
, DifferentialBaseLSN numeric(25,0) NULL
, DifferentialBaseGUID uniqueidentifier
, BackupTypeDescription nvarchar(60)
, BackupSetGUID uniqueidentifier NULL
, CompressedBackupSize bigint NULL
, containment tinyint not NULL
, KeyAlgorithm nvarchar(32)
, EncryptorThumbprint varbinary(20)
, EncryptorType nvarchar(32)
)

注意事项:
请参阅定义中的最后四个字段。
字段 containment tinyint not NULL 已添加到 SQL-Server 2012 中,因此您还必须添加此字段(如果尚未添加)。
我只是在定义的末尾添加了新字段.. 现在一切都像以前一样工作(没有进一步的变化)。

所以.. 这是对 SQL-Server 2014 SP1重大更改,因为您在 SP 中使用了 restoreheader 定义。我没有在官方 MS 发行说明中找到任何相关信息(必须更改)。只有我找到的信息,见下文......

“SQL Server 2014 Service Pack 1 发布信息”的 MS 文本:

1957464 RESTORE HEADERONLY for an Encrypted Backup file of the Database does not show whether the backup is encrypted or not. After you apply SP1, the output of RESTORE HEADONLY will include three additional columns: KeyAlgorithm, EncryptorThumbprint and EncryptorType that can give additional details about the encrypted backup.

关于sql-server - 将 sp1 应用于 SQL Server 2014 后 RESTORE HEADERONLY 错误 3013,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32631135/

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