7

如果我希望离线或在线使用 MS Sql 2008,我需要使用 GUI -> DB-Tasks-Take Online 或 Take Offline。

这可以用一些sql脚本来完成吗?

4

4 回答 4

11
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
于 2009-05-11T07:32:32.207 回答
3

我知道这是一篇旧文章,但是以防万一有人遇到此解决方案并且更喜欢不执行但返回脚本的非游标方法。我刚刚采用了以前的解决方案并将其转换为基于结果构建的选择。

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
于 2012-04-04T07:14:57.870 回答
3
-- 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;

在运行该过程之前重新启动服务器。它将关闭与数据库的现有连接。

于 2012-01-13T20:46:38.313 回答
2

这是一个可能对您非常有用的注释:几乎总是可以看到 GUI 在幕后 TSQLwise 正在做什么。

c : http://www.mssqltips.com/tip.asp?tip=1505

于 2009-05-11T07:54:36.710 回答