当前位置: 首页 > 图文教程 > 数据库 > MSSQL > 拷贝的SQLServer7数据库的恢复方法

MSSQL
在SQL Server下数据库链接的使用
SQL Server数据库中处理空值时常见问题
巧用一条SQL语句实现其它进制到十进制转换
通过JDBC连接DB2数据库技巧
深入浅出SQL教程之嵌套SELECT语句
SQL Server备份文件中导入现存数据库
SQL多表格查询合并至单一声明的常用方式
也谈如何缩小SQL SERVER日志文件
四个语句帮你提高 SQL Server 的伸缩性
用JavaBean编写SQL Server数据库连接类
sql2k中新增加的Function的sqlbook 的帮助
Mssql处理孤立用户的存储过程
探讨SQL Server中Case 的不同用法
快速清除SQLServer日志的两种方法
解决Sql Server警报的疑难问题
MySQL的数据类型和建库策略
SQL SERVER应用问题解答13例(一)
SQL SERVER应用问题解答13例(二)
多种还原.bak数据库文件方式
SQL语句中的一些特殊参数如何用变量来代替

MSSQL 中的 拷贝的SQLServer7数据库的恢复方法


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 141 ::
收藏到网摘: n/a

在SQL Server 7中由于MS重新设计了数据库文件的存储方式,取消了新建设备再建数据库这一繁琐的过程。新的存储格式,一个数据库包括两个文件,mdf数据库文件和ldf日志文件。所以我们在重装机器备份时可以把你要备份的数据库的这两个文件拷贝出来,重新安装之后再恢复。

在SQL Server中提供了这种恢复方式的存储过程。

1.

sp_attach_db [@dbname =] 'dbname',[@filename1 =] 'filename_n'

给系统添加一个数据库,在dbname指定数据库名称,filename_n指定数据库的文件和日志文件。比如我有一个voogiya的库,停止SQL Server服务备份voogiya_data.mdf,voogiya_log.ldf,启动SQL server,删除掉这个库,然后再把这两上文件拷到sql server DATA目录中,在Query Analyzer中执行如下语句:

EXEC sp_attach_db @dbname = N'voogiya',@filename1 = N'd:mssql7datavoogiya_data.mdf',@filename2 = N'd:mssql7datavoogiya_log.ldf'

就会把这个库加入到SQL Server Group中.

2.

sp_attach_single_file_db [@dbname =] 'dbname',[@physname =] 'physical_name'

这个命令和上面的功能一样,在physical_name中只要写上据库的物理文件名就可以了,日志文件SQL server会重新建立。这个存储过程的运行要先执行下面的存储过程:

sp_detach_db @dbname = 'dbname'

同样以上面的为例:

EXEC sp_detach_db @dbname = 'voogiya'EXEC sp_attach_single_file_db @dbname = 'voogiya',@physname = 'd:mssql7datavoogiya_data.mdf'

要注意执行以上存储过程的用户要在sysadmin中.

以上方法在windows Nt 4.0,service pack5,sql server 7.0上运行通过。