zoukankan      html  css  js  c++  java
  • SqlServer: 单用户模式下查杀相关进程实现单/多用户转换 .

    SQLServer下,单/多用户模式转换的三种方法:

      1.直接在Management Studio中设置相关数据库的Properties:Options-->Restrict Access下设置MULTI/SINGLE_USER。

       2.若是其他人设置Server为单用户模式,或者其他未知进程占用操作DB,再使用第一种方法发现该DB的Properties是打不开的,这时应该使用如下T-SQL进行操作:

    -----------------------Conversion Between Single Modle and  Multiple Modle,the first method:
    EXEC   sp_dboption   @dbname   =   'DB Name',   @optname   =   'single   user ',   @optvalue   =   false 
    EXEC   sp_dboption   @dbname   =   'DB Name ',   @optname   =   'single   user ',   @optvalue   =   true 
    


      3.也可以直接更改DB模式:

    -----------------------Conversion Between Single Modle and  Multiple Modle,the second method:
    ALTER DATABASE DealManager SET MULTI_USER
    AlTER DATABASE DEALMANAGER SET SINGLE_USER
    


      倘若在单用户模式下恢复多用户模式或者操作DB发现操作总是失败,这是因为有其他进程占用该DB的缘故,有人会直接手动查看监视器中的进程,把与目的库有关的KILL掉,这种方法是很粗糙的,效率低而且有操作错误进程的危险。其实,实时操作DB的进程在master中是有记录的,我们只需要一个select语句就知道该进程,  然后Kill相关进程:

    1. ----------------------Kill the process in Single Modle   
    2. select * from master..sysprocesses  
    3. where dbid=db_id('DB Name')  
    4. --Kill spid  

    也写了个小脚本执行这个操作:

    1. DECLARE @kid varchar(100)  
    2. SET @kid=''  
    3. SELECT @kid=@kid+'KILL'+CAST(spid as Varchar(10))  
    4. FROM master..sysprocesses  
    5. WHERE dbid=DB_ID('DB Name')  
    6. PRINT @kid  
    7. EXEC(@kid)  
  • 相关阅读:
    从零开始学android开发-通过WebService获取今日天气情况
    android常见错误-E/AndroidRuntime(13678): java.lang.NoClassDefFoundError:
    java 使用相对路径读取文件
    冒泡排序
    快速排序
    为什么使用抽象类?有什么好处?
    为什么用 抽象类,接口
    String.valueOf()
    Python 资源
    文本相似度-BM25算法
  • 原文地址:https://www.cnblogs.com/songsz1/p/2660064.html
Copyright © 2011-2022 走看看