如果我希望离线或在线使用 MS Sql 2008,我需要使用 GUI -> DB-Tasks-Take Online 或 Take Offline。
这可以用一些sql脚本来完成吗?
如果我希望离线或在线使用 MS Sql 2008,我需要使用 GUI -> DB-Tasks-Take Online 或 Take Offline。
这可以用一些sql脚本来完成吗?
ALTER DATABASE database-name SET OFFLINE
如果您在连接用户或进程时运行ALTER DATABASE命令,但您不希望该命令被阻止,则可以使用 NO_WAIT 选项执行该语句。这会导致命令失败并出现错误。
ALTER DATABASE database-name SET OFFLINE WITH NO_WAIT
网上对应:
ALTER DATABASE database-name SET ONLINE
我知道这是一篇旧文章,但是以防万一有人遇到此解决方案并且更喜欢不执行但返回脚本的非游标方法。我刚刚采用了以前的解决方案并将其转换为基于结果构建的选择。
DECLARE @SQL VARCHAR(8000)
SELECT @SQL=COALESCE(@SQL,'')+'ALTER DATABASE '+name+ N' SET OFFLINE WITH NO_WAIT;
'
FROM sys.databases
WHERE owner_sid<>0x01
PRINT @SQL
-- Take all user databases offline
CREATE PROCEDURE SP_TakeOfflineAllDatabase AS
BEGIN
DECLARE @db sysname, @q varchar(max);
DECLARE cur_db CURSOR FOR
SELECT name FROM sys.databases WHERE owner_sid<>0x01;
OPEN cur_db;
WHILE 1=1
BEGIN
FETCH NEXT FROM cur_db INTO @db;
IF @@FETCH_STATUS <> 0
BREAK;
SET @q = N'ALTER DATABASE [' + @db + N'] SET OFFLINE WITH NO_WAIT';
EXEC(@q);
END;
CLOSE cur_db;
DEALLOCATE cur_db;
END;
在运行该过程之前重新启动服务器。它将关闭与数据库的现有连接。
这是一个可能对您非常有用的注释:几乎总是可以看到 GUI 在幕后 TSQLwise 正在做什么。