- PR -

最新のバックアップセットからリストアする

1
投稿者投稿内容
未記入
会議室デビュー日: 2005/06/27
投稿数: 13
投稿日時: 2008-08-19 17:48
お世話になっております。

SQL Server2005にて、複数のバックアップセットを含むバックアップファイルから、
最新のバックアップセットでリストアを行うバッチを作成しています。
(常に完全バックアップ、復元モデルは「シンプル」)

RESTORE DATABASE コマンドのFILEオプションに最新のバックアップセットの番号を
渡せばいいのは分かるのですが、最新の番号を取得することができず詰まっています。

現状は以下のようになっています。

== リストア用SQL =================================================
RESTORE DATABASE データベース名
FROM DISK = 'バックアップファイルのパス'
WITH FILE = 【ココの最新が取得できない!】
==================================================================

== バックアップセット番号取得用SQL ===============================
SELECT
Position
FROM
(
RESTORE HEADERONLY
FROM DISK = 'バックアップファイルのパス'
WITH NOUNLOAD
) as BackUpFiles
↑この副問い合わせは出来ないらしい
==================================================================

どなたか助言をお願いします。
未記入
会議室デビュー日: 2005/06/27
投稿数: 13
投稿日時: 2008-08-19 18:48
自己レスです。

一応、以下のSQLで最新のファイル番号は取得できました。

======================================================
create table #temp (
BackupName nvarchar(128),
BackupDescription nvarchar(255),
BackupType smallint,
ExpirationDate datetime,
Compressed char(1),
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),
RecoveryModel nvarchar(60),
DifferentialBaseLSN numeric(25,0),
DifferentialBaseGUID uniqueidentifier,
BackupTypeDescription nvarchar(60),
BackupSetGUID uniqueidentifier)

declare @a varchar(256)
select @a='restore headeronly from disk= N''バックアップファイルのパス'''

insert #temp exec (@a)

select
max(position) as position
from
#temp

drop table #temp
======================================================

値を一つ取得するのにあんまりなSQLになってしまいました。
引き続き、ご意見をお願いします。
1

スキルアップ/キャリアアップ(JOB@IT)