SqlServer: 单用户模式下查杀相关进程实现单/多用户转换 .
2012-08-28 12:51 立雪三尺 阅读(1967) 评论(2) 编辑 收藏 举报SQLServer下,单/多用户模式转换的三种方法:
1.直接在Management Studio中设置相关数据库的Properties:Options-->Restrict Access下设置MULTI/SINGLE_USER。
2.若是其他人设置Server为单用户模式,或者其他未知进程占用操作DB,再使用第一种方法发现该DB的Properties是打不开的,这时应该使用如下T-SQL进行操作:
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相关进程:
- ----------------------Kill the process in Single Modle
- select * from master..sysprocesses
- where dbid=db_id('DB Name')
- --Kill spid
也写了个小脚本执行这个操作:
- DECLARE @kid varchar(100)
- SET @kid=''
- SELECT @kid=@kid+'KILL'+CAST(spid as Varchar(10))
- FROM master..sysprocesses
- WHERE dbid=DB_ID('DB Name')
- PRINT @kid
- EXEC(@kid)
作者:立雪三尺
出处:http://www.cnblogs.com/songsz1/
我滴生命是如此滴辉煌!我滴生活是如此滴灿烂!
关于作者:初出茅庐,职场菜鸟。静如瘫痪,动若癫痫。!姓名不知,生死不详!
如有问题或建议,请多多赐教! 如无,出门左转是政府。
本文版权归作者所有,欢迎转载,不一定非得在显眼处给出原文链接
如有想不开的暴击我
最后严重警告:本文作者真的是名程序员。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述