SQL script to “copy” a database

后端 未结 7 610
名媛妹妹
名媛妹妹 2020-12-14 20:46

I want to write a SQL script that will copy a database on the same server. I could do a backup/restore, but I think it might be faster to just \"copy\" somehow. Does anyon

7条回答
  •  暖寄归人
    2020-12-14 21:13

    Here is a version of the code Tony posted which works in SQL Server 2005

    USE master
    GO
    -- the original database (use 'SET @DB = NULL' to disable backup)
    DECLARE @DB varchar(200)
    SET @DB = 'GMSSDB'
    -- the backup filename
    DECLARE @BackupFile varchar(2000)
    SET @BackupFile = 'c:\temp\backup.dat'
    -- the new database name
    DECLARE @TestDB varchar(200)
    SET @TestDB = 'GMSSDBArchive'
    -- the new database files without .mdf/.ldf
    DECLARE @RestoreFile varchar(2000)
    SET @RestoreFile = 'c:\temp\backup'
    -- ****************************************************************
    -- no change below this line
    -- ****************************************************************
    
    DECLARE @query varchar(2000)
    DECLARE @DataFile varchar(2000)
    SET @DataFile = @RestoreFile + '.mdf'
    DECLARE @LogFile varchar(2000)
    SET @LogFile = @RestoreFile + '.ldf'
    IF @DB IS NOT NULL
    BEGIN
    SET @query = 'BACKUP DATABASE ' + @DB + ' TO DISK = ' + QUOTENAME(@BackupFile, '''')
    EXEC (@query)
    END
    -- RESTORE FILELISTONLY FROM DISK = 'C:\temp\backup.dat'
    -- RESTORE HEADERONLY FROM DISK = 'C:\temp\backup.dat'
    -- RESTORE LABELONLY FROM DISK = 'C:\temp\backup.dat'
    -- RESTORE VERIFYONLY FROM DISK = 'C:\temp\backup.dat'
    IF EXISTS(SELECT * FROM sysdatabases WHERE name = @TestDB)
    BEGIN
    SET @query = 'DROP DATABASE ' + @TestDB
    EXEC (@query)
    END
    
    CREATE TABLE #headeronly
    (
    BackupName nvarchar(128) null,
    BackupDescription nvarchar(255) null,
    BackupType smallint,
    ExpirationDate datetime  null,
    Compressed bit,
    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
    )
    --RESTORE HEADERONLY FROM DISK = @BackupFile
    SET @query = 'RESTORE HEADERONLY FROM DISK = ' + QUOTENAME(@BackupFile, '''')
    INSERT #headeronly exec(@query)
    
    
    DECLARE @File int
    select @File = count(1) from #headeronly
    print CONVERT(varchar, @File)
    DROP TABLE #headeronly
    
    
    DECLARE @Data varchar(500)
    DECLARE @Log varchar(500)
    SET @query = 'RESTORE FILELISTONLY FROM DISK = ' + QUOTENAME(@BackupFile , '''')
    
    --RESTORE FILELISTONLY FROM DISK = 'c:\temp\backup.dat'
    
    CREATE TABLE #restoretemp
    (
    LogicalName nvarchar(128),
    PhysicalName nvarchar(260),
    type char(1),
    FilegroupName nvarchar(128),
    size numeric(20,0),
    maxsize numeric(20,0),
    FileID bigint,
    CreateLSN numeric(25,0),
    DropLSN numeric(25,0 )NULL,
    UniqueID uniqueidentifier,
    ReadOnlyLSN numeric(25,0) NULL,
    ReadWriteLSN numeric(25,0) NULL,
    BackupSizeInBytes bigint,
    SourceBlockSize int,
    FileGroupID int,
    LogGroupGUID uniqueidentifier NULL,
    DifferentialBaseLSN numeric(25,0) NULL,
    DifferentialBaseGUID uniqueidentifier,
    IsReadOnly bit,
    
    IsPresent bit
    
    )
    --select * from EXEC (@query)
    INSERT #restoretemp EXEC (@query)
    SELECT @Data = LogicalName FROM #restoretemp WHERE type = 'D'
    SELECT @Log = LogicalName FROM #restoretemp WHERE type = 'L'
    PRINT @Data
    PRINT @Log
    TRUNCATE TABLE #restoretemp
    DROP TABLE #restoretemp
    print CONVERT(varchar, @File)
    IF @File > 0
    BEGIN
    
    SET @query = 'RESTORE DATABASE ' + @TestDB + ' FROM DISK = ' + QUOTENAME(@BackupFile, '''') +
    ' WITH MOVE ' + QUOTENAME(@Data, '''') + ' TO ' + QUOTENAME(@DataFile, '''') + ', MOVE ' +
    QUOTENAME(@Log, '''') + ' TO ' + QUOTENAME(@LogFile, '''') + ', FILE = ' + CONVERT(varchar, @File)
    print 'starting restore'
    EXEC (@query)
    print 'finished restore'
    END
    GO
    

提交回复
热议问题