Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sql-server/24.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sql 尝试附加.mdf时出错_Sql_Sql Server - Fatal编程技术网

Sql 尝试附加.mdf时出错

Sql 尝试附加.mdf时出错,sql,sql-server,Sql,Sql Server,我试图将带有数据的数据库从s3机器导入到我的本地机器,为此,我已将数据库从s3机器上分离,并复制了数据库并粘贴到本地机器上,路径为“D:\Databases\MSSQL\OLTP\data\Test\u AS.mdf” 现在,当我尝试将此mdf文件附加到SQL server实例时,它显示了一条错误消息: Attach database failed for the server Add

我试图将带有数据的数据库从s3机器导入到我的本地机器,为此,我已将数据库从s3机器上分离,并复制了数据库并粘贴到本地机器上,路径为“D:\Databases\MSSQL\OLTP\data\Test\u AS.mdf” 现在,当我尝试将此mdf文件附加到SQL server实例时,它显示了一条错误消息:

Attach database failed for the server                                                        
Additional Information :                                                                     
     An exception occurred while executing Transact-SQL statement or batch
(Microsoft.SqlServer.Connectioninfo)                                                       
         Unable to open the physical file "D:\Databases\MSSQL\OLTP\Data\Test_AS_log " Operating system error 2 : 2(failed to retrieve text for this error.Reason : 15105)"."(Microsoft SQL Server Error : 5120)"

SQL Server有权对该位置执行此操作。

附加数据文件和日志文件时,您需要同时指定它们:

CREATE DATABASE DataBaseName
    ON (FILENAME = 'D:\Databases\MSSQL\OLTP\Data\Test_AS.mdf'), 
    (FILENAME = 'D:\Databases\MSSQL\OLTP\Data\Test_AS_log.ldf') 
    FOR ATTACH; 

我也有类似的问题。原来问题的原因是.mdf和.ldf文件都被压缩了,因为D:drive已选中“压缩此驱动器以节省磁盘空间”

而且,由于这个原因,我甚至不能在D:上创建新的数据库。 通过取消选中Properties/Advanced中.mdf和.ldf文件的“压缩内容以节省磁盘空间”来解决此问题


SQL Server是否具有访问该位置的权限?文件是否与此完全相同(不包括文件扩展名)?找不到操作系统错误2,这清楚地表明您为文件指定了无效位置或文件名存在问题。您是否确实在该位置有名为
Test\u AS\u Log
(没有扩展名和空格)的文件?您是否正在尝试将其连接到远程SQL Server计算机?如果是这样的话,是远程机器的D:\drive??Ken White上的文件吗?不,它不包含该文件,实际上它在尝试将数据库附加到SQL Server实例时必须默认创建日志文件。但是它显示了一些类似于我前面提到的错误。而且SQL Server具有访问该位置的权限。