SQL SERVER数据库导入问题
我想将一个异地SQL SERVER数据库文件*.MDF导入本地SQL SERVER管理,怎么办?
急急急
问题点数:39、回复次数:8Top
1 楼guasha(刮痧)回复于 2001-12-26 15:48:10 得分 10
sp_attach_dbTop
2 楼fish1977(小鱼儿)回复于 2001-12-26 15:52:19 得分 0
你可以通过SQL SERVER数据库的导出功能,不一定非要它自己的*.MDF,导入你的SQL SERVER中生成MDF文件Top
3 楼zzxcom(冥顽不化)回复于 2001-12-26 20:52:08 得分 0
导出功能?我是想解开人家给我的程序中用到的数据库文件,但没有SQL 企业管理器的帮忙,我是看不到数据库结构的阿。我一定要用原来的*.MDF阿。有没有办法?Top
4 楼zzxcom(冥顽不化)回复于 2001-12-26 21:36:36 得分 0
刮痧,您可以不可以详细讲解一下这命令怎样执行的?Top
5 楼tangqin(吞云)回复于 2001-12-27 00:21:02 得分 12
SP_attach_db 用法如下:
EXEC SP_attach_db @dbname = N'目标数据库名', //这是你要引入后的数据库名。
@filename1 = N'源数据库DATA文件完整路径及文件名.MDF', //指明源数据库的数据文件
@filename2 = N'源数据库LOG文件完整路径及文件名.LDF' //指明源数据库日志文件
注:最后一行不要加逗号。
《参见T-SQL 存储过程和表引用》 清华大学出版社
Top
6 楼shinebei(灰灰)回复于 2001-12-27 08:34:46 得分 17
sp_attach_db
将数据库附加到服务器。
语法
sp_attach_db [ @dbname = ] 'dbname'
, [ @filename1 = ] 'filename_n' [ ,...16 ]
参数
[@dbname =] 'dbname'
要附加到服务器的数据库的名称。该名称必须是唯一的。dbname 的数据类型为 sysname,默认值为 NULL。
[@filename1 =] 'filename_n'
数据库文件的物理名称,包括路径。filename_n 的数据类型为 nvarchar(260),默认值为 NULL。最多可以指定 16 个文件名。参数名称以 @filename1 开始,递增到 @filename16。文件名列表至少必须包括主文件,主文件包含指向数据库中其它文件的系统表。该列表还必须包括数据库分离后所有被移动的文件。
返回代码值
0(成功)或 1(失败)
结果集
无
注释
只应对以前使用显式 sp_detach_db 操作从数据库服务器分离的数据库执行 sp_attach_db。如果必须指定多于 16 个文件,请使用带有 FOR ATTACH 子句的 CREATE DATABASE。
如果将数据库附加到的服务器不是该数据库从中分离的服务器,并且启用了分离的数据库以进行复制,则应该运行 sp_removedbreplication 从数据库删除复制。
权限
只有 sysadmin 和 dbcreator 固定服务器角色的成员才能执行本过程。
示例
下面的示例将 pubs 中的两个文件附加到当前服务器。
EXEC sp_attach_db @dbname = N'pubs',
@filename1 = N'c:\Program Files\Microsoft SQL Server\MSSQL\Data\pubs.mdf',
@filename2 = N'c:\Program Files\Microsoft SQL Server\MSSQL\Data\pubs_log.ldf'
Top
7 楼guasha(刮痧)回复于 2001-12-27 09:10:41 得分 0
我来晚了,
建议你装一各SQL2000中文版,帮助很详细,而且是中文的
Top
8 楼zzxcom(冥顽不化)回复于 2001-12-27 20:55:09 得分 0
如果损失日志文件*.ldf怎么办?好像加不了了。
各位再帮帮忙啊Top




