1、没有数据库时先创建一个同名数据库,然后选择备份,此时需要全备份,分量备份不可以 如果都正常操作还提示备份集中的数据库备份与现有不同则用语句执行 restore database workpointmanage_sassfrom disk = c:\program files\microsoft sql server\mssql10
1、没有数据库时先创建一个同名数据库,然后选择备份,此时需要全备份,分量备份不可以
如果都正常操作还提示“备份集中的数据库备份与现有不同”则用语句执行
restore database workpointmanage_sassfrom disk = 'c:\program files\microsoft sql server\mssql10_50.mssqlserver\mssql\backup\workpointmanage_sass_datafull_201412040742_12040742.bak' --bak文件路径with replace,move 'workpointmanage_sass' to 'c:\program files\microsoft sql server\mssql10_50.mssqlserver\mssql\data\workpointmanage_sass.mdf', --mdf文件路径move 'workpointmanage_sass_log' to 'c:\program files\microsoft sql server\mssql10_50.mssqlserver\mssql\data\workpointmanage_sass.ldf' --ldf文件路径
2、数据库还原中提示数据库正在被占用,需要分离数据库再联机,手动操作无效时可用如下语句
declare @dbname varchar(20)set @dbname='workpointmanage_sass'declare @sql nvarchar(500)declare @spid int--spid 值是当用户进行连接时指派给该连接的一个唯一的整数set @sql='declare getspid cursor forselect spid from sysprocesses where dbid=db_id('''+@dbname+''')'exec (@sql)open getspidfetch next from getspid into @spidwhile @@fetch_status-1--如果fetch 语句没有执行失败或此行不在结果集中。beginexec('kill '+@spid)--终止正常连接fetch next from getspid into @spidendclose getspiddeallocate getspid