我使用这个查询重命名数据库:

ALTER DATABASE BOSEVIKRAM MODIFY NAME = [BOSEVIKRAM_Deleted]

但它在执行时显示一个错误:

呼叫5030,16层,状态2,1线 数据库无法被排他锁定以执行该操作。

我的查询有什么问题吗?


当前回答

SQL Server Management Studio (SSMS)中:

你也可以在对象资源管理器中右键单击你的数据库,然后转到属性。从那里,进入选项。向下滚动并将限制访问设置为SINGLE_USER。更改数据库名称,然后返回并将其设置为MULTI_USER。

其他回答

这是因为其他人正在访问数据库。将数据库设置为单用户模式,然后重命名它。

这个链接可能会有帮助: http://msdn.microsoft.com/en-IN/library/ms345378 (v = sql.105) . aspx

还有: http://msdn.microsoft.com/en-us/library/ms345378.aspx

SQL Server Management Studio (SSMS)中:

你也可以在对象资源管理器中右键单击你的数据库,然后转到属性。从那里,进入选项。向下滚动并将限制访问设置为SINGLE_USER。更改数据库名称,然后返回并将其设置为MULTI_USER。

use master

ALTER DATABASE BOSEVIKRAM SET SINGLE_USER WITH ROLLBACK IMMEDIATE  

exec sp_renamedb 'BOSEVIKRAM','BOSEVIKRAM_Deleted'

ALTER DATABASE BOSEVIKRAM_Deleted SET MULTI_USER

关闭所有连接的另一种方法:

管理工具>查看本地服务

停止/启动“SQL Server (MSSQLSERVER)”服务

1.数据库设置第一个单用户模式

修改数据库bosevikram,设置single_user立即回滚

2.重命名数据库

修改数据库名称= [bosevikram_delete]

3.数据库设置多用户模式

修改数据库回滚立即的多用户