>  기사  >  데이터 베이스  >  数据库备份遇到的问题

数据库备份遇到的问题

WBOY
WBOY원래의
2016-06-07 16:12:101175검색

1、没有数据库时先创建一个同名数据库,然后选择备份,此时需要全备份,分量备份不可以 如果都正常操作还提示备份集中的数据库备份与现有不同则用语句执行 RESTORE DATABASE workpointmanage_sassFROM DISK = C:\Program Files\Microsoft SQL Server\MSSQL10

1、没有数据库时先创建一个同名数据库,然后选择备份,此时需要全备份,分量备份不可以

如果都正常操作还提示“备份集中的数据库备份与现有不同”则用语句执行

 

RESTORE DATABASE workpointmanage_sass
FROM 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 for

select spid from sysprocesses where dbid=db_id('''+@dbname+''')'

exec (@sql)

open getspid

fetch next from getspid into @spid

while @@fetch_status<>-1--如果FETCH 语句没有执行失败或此行不在结果集中。

begin

exec(&#39;kill &#39;+@spid)--终止正常连接

fetch next from getspid into @spid

end

close getspid

deallocate getspid

 

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.