淺談如何在SQL Server 2008中附加一個(gè)數(shù)據(jù)庫(kù)
51CTO向您推薦《SQL Server 2008深度應(yīng)用》,相信通過(guò)本專(zhuān)題,能讓您更深刻的了解SQL Server 2008。
在SQL Server 7.0中,微軟推出了sp_attach_db和sp_attach_single_file_db系統(tǒng)存儲(chǔ)過(guò)程。它對(duì)于SQL Server數(shù)據(jù)庫(kù)管理員執(zhí)行下面的任務(wù)是非常方便的:
使用sp_attach_db系統(tǒng)存儲(chǔ)過(guò)程直接將.MDF和.LDF文件附加到服務(wù)器。
使用sp_attach_single_file_db系統(tǒng)存儲(chǔ)過(guò)程只附加.MDF文件。
使用sp_detach_db將數(shù)據(jù)庫(kù)從一個(gè)服務(wù)器分離,復(fù)制.MDF文件到另一個(gè)服務(wù)器上,然后使用sp_attach_db系統(tǒng)存儲(chǔ)過(guò)程重新附加這些文件到兩個(gè)服務(wù)器上。
盡管它對(duì)于SQL Server數(shù)據(jù)庫(kù)管理員是很有用的,但是在使用這兩個(gè)存儲(chǔ)過(guò)程時(shí)是有一些限制的。限制如下:
你不能附加多個(gè)日志文件
你不能附加16個(gè)以上的文件
在SQL Server 2008中,微軟宣布上面的系統(tǒng)存儲(chǔ)過(guò)程將在未來(lái)的版本中被廢棄。而他們?cè)?ldquo;Create Database”SQL語(yǔ)句中添加了一個(gè)從句“For Attach”。
這篇文章將介紹使用“For Attach”從句的多種方法,以克服在使用sp_attach_db和sp_attach_single_file_db時(shí)要面臨的限制。
假設(shè)我們有一個(gè)數(shù)據(jù)庫(kù)叫“MyDB1”,它有一個(gè).MDF文件和一個(gè).LDF文件。使用下面的事務(wù)SQL語(yǔ)句創(chuàng)建這個(gè)數(shù)據(jù)庫(kù)。再假設(shè).MDF文件和.LDF文件的位置是“C:Program FilesMicrosoft SQL ServerMSSQL10.SQL2008MSSQLDATASummary Database DataData File for Monthly ArchiveMicrosoft SQL Server 2008 Data File”。
- Use Master
- go
- CREATE DATABASE MyDB1
- ON
- ( NAME = MyDB1_dat,
- FILENAME = 'C:Program Files
- Microsoft SQL ServerMSSQL10.SQL2008MSSQLDATA
- Summary Database DataData File for Monthly Archive
- Microsoft SQL Server 2008 Data FileMyDB1.mdf',
- SIZE = 10,
- MAXSIZE = 50,
- FILEGROWTH = 5 )
- LOG ON
- ( NAME = MyDB1_log,
- FILENAME = 'C:Program Files
- Microsoft SQL ServerMSSQL10.SQL2008MSSQLDATA
- Summary Database DataData File for Monthly Archive
- Microsoft SQL Server 2008 Data FileMyDB1.ldf',
- SIZE = 5MB,
- MAXSIZE = 25MB,
- FILEGROWTH = 5MB )
- GO
現(xiàn)在,讓我們分離該數(shù)據(jù)庫(kù),并嘗試使用sp_detach_db和 sp_attach_db將它重新附加。執(zhí)行下面的事務(wù)SQL語(yǔ)句。
- use master
- go
- sp_detach_db 'MyDB1'
- go
- sp_attach_db 'MyDb1',
- 'C:Program FilesMicrosoft SQL ServerMSSQL10.SQL2008MSSQLDATASummary Database Data
- Data File for Monthly ArchiveMicrosoft SQL Server 2008 Data FileMyDB1.mdf',
- 'C:Program FilesMicrosoft SQL ServerMSSQL10.SQL2008MSSQLDATASummary Database Data
- Data File for Monthly ArchiveMicrosoft SQL Server 2008 Data FileMyDB1.ldf'
- GO
- 你可以使用具有“For Attach”從句的“Create database”命令附加上相同的數(shù)據(jù)庫(kù)文件,如下所示。
- use master
- go
- sp_detach_db 'MyDB1'
- go
- CREATE DATABASE MyDB1
- ON
- (
- FILENAME = 'C:Program FilesMicrosoft SQL ServerMSSQL10.SQL2008MSSQLDATASummary Database Data
- Data File for Monthly ArchiveMicrosoft SQL Server 2008 Data FileMyDB1.mdf'
- ),
- (
- FILENAME = 'C:Program FilesMicrosoft SQL ServerMSSQL10.SQL2008MSSQLDATASummary Database Data
- Data File for Monthly ArchiveMicrosoft SQL Server 2008 Data FileMyDB1.ldf'
- ) for Attach
- go
現(xiàn)在,讓我們分離數(shù)據(jù)庫(kù)MyDB1,然后刪除.ldf文件,再然后使用sp_attach_single_file_db系統(tǒng)存儲(chǔ)過(guò)程通過(guò)執(zhí)行下面的TSQL命令將它重新附加上。
- use master
- go
- sp_detach_db 'MyDB1'
- go
- exec master..xp_cmdshell 'del "C:Program FilesMicrosoft SQL ServerMSSQL10.SQL2008MSSQLDATASummary Database Data
- Data File for Monthly ArchiveMicrosoft SQL Server 2008 Data FileMyDB1.ldf"'
- go
注意:我使用xp_cmdshell來(lái)刪除.ldf文件。如果xp_cmdshell沒(méi)有激活,那么你將得到下面的錯(cuò)誤。
錯(cuò)誤:
- Msg 15281, Level 16, State 1, Procedure xp_cmdshell, Line 1
- SQL Server blocked access to procedure 'sys.xp_cmdshell' of component 'xp_cmdshell'
- because this component is turned off as part of the security configuration for
- this server. A system administrator can enable the use of 'xp_cmdshell' by using
- sp_configure. For more information about enabling 'xp_cmdshell', see
- "Surface Area Configuration" in SQL Server Books Online.
你可以使用下面的事務(wù)SQL語(yǔ)句來(lái)激活xp_cmdshell?!?/p>
- use master
- go
- sp_configure 'show advanced options',1
- go
- reconfigure with override
- go
- sp_configure 'xp_cmdshell',1
- go
- reconfigure with override
- go
或者,你可以在MS-DOS命令提示符中使用Windows資源管理器的“Del”命令來(lái)刪除.ldf文件。
現(xiàn)在,讓我們只使用sp_attach_single_file_db來(lái)附加.MDF文件。執(zhí)行下面所示的命令。
- use master
- go
- sp_attach_single_file_db 'MyDB1',
- 'C:Program FilesMicrosoft SQL ServerMSSQL10.SQL2008MSSQLDATASummary Database Data
- Data File for Monthly ArchiveMicrosoft SQL Server 2008 Data FileMyDB1.mdf'
- go
結(jié)果
- File activation failure. The physical file name
- "C:Program FilesMicrosoft SQL ServerMSSQL10.SQL2008MSSQLDATASummary Database Data
- Data File for Monthly ArchiveMicrosoft SQL Server 2008 Data FileMyDB1.ldf" may be incorrect.
- New log file 'C:Program FilesMicrosoft SQL ServerMSSQL10.SQL2008MSSQLDATASummary Database Data
- Data File for Monthly ArchiveMicrosoft SQL Server 2008 Data FileMyDB1_log.LDF' was created.
你可以只通過(guò)使用帶有“For ATTACH_REBUILD_LOG”從句的“Create database”命令來(lái)附加相同的數(shù)據(jù)庫(kù).MDF文件,如下所示。
- use master
- go
- sp_detach_db 'MyDB1'
- go
- exec master..xp_cmdshell 'del
- "C:Program FilesMicrosoft SQL ServerMSSQL10.SQL2008MSSQLDATASummary Database Data
- Data File for Monthly ArchiveMicrosoft SQL Server 2008 Data FileMyDB1_log.ldf"'
- go
注意:當(dāng)日志文件被重新創(chuàng)建時(shí),SQL Server自動(dòng)對(duì)日志文件名稱(chēng)添加后綴“_log”。
- CREATE DATABASE MyDB1
- ON
- (
- FILENAME = 'C:Program FilesMicrosoft SQL ServerMSSQL10.SQL2008MSSQLDATASummary Database Data
- Data File for Monthly ArchiveMicrosoft SQL Server 2008 Data FileMyDB1.mdf'
- ) for ATTACH_REBUILD_LOG
結(jié)果:
- File activation failure. The physical file name "C:Program FilesMicrosoft SQL Server
- MSSQL10.SQL2008MSSQLDATASummary Database DataData File for
- Monthly ArchiveMicrosoft SQL Server 2008 Data FileMyDB1_log.LDF" may be incorrect.
- New log file 'C:Program FilesMicrosoft SQL ServerMSSQL10.SQL2008MSSQLDATASummary Database
- DataData File for Monthly ArchiveMicrosoft SQL Server 2008 Data FileMyDB1_log.LDF' was created.
總結(jié)
本文介紹了帶有“For Attach”和“for ATTACH_REBUILD_LOG”用于一個(gè)單獨(dú)的.MDF文件和一個(gè)單獨(dú)的.LDF文件的“Create Database”語(yǔ)句的使用。
【編輯推薦】
- SQL Server 2008行數(shù)據(jù)和頁(yè)數(shù)據(jù)壓縮解密
- 圖解SQL Server 2008 R2主數(shù)據(jù)服務(wù)安裝
- 理解SQL Server 2008索引的存儲(chǔ)結(jié)構(gòu)
- SQL Server移動(dòng)系統(tǒng)數(shù)據(jù)庫(kù)開(kāi)發(fā)詳解
- SQL Server 2008 R2十大新特性解析