明凯博客

关注网站技术,一个特立独行的程序员

MSSQL Server 异常 21776:[SQL-DMO]名称”dbo”在Users集合中

MSSQL Server 错误 21776:[SQL-DMO]名称”dbo”在Users集合中

问题:
在企业管理器里面修改sa密码并确认新密码之后遇到如下错误信息:
错误 21776:[SQL-DMO]名称”dbo”在Users集合中没有找到,如果该名称是合法名称,则使用[]来分隔名称的不同部分,然后重试。

分析和解答:

每个数据库内都有一个称为dbo的特殊用户,固定服务器角色sysadmin的任何成员都影射到dbo上。如果某个数据库内的dbo用户对应的登录,在另外一台SQL Server服务器里面不存在的话,那么当将这个数据库的备份还原到另外一台SQL Server服务器时,dbo用户所对应的登录名就会为空。正是因为这个原因,系统不允许修改sa密码。
解决步骤如下:
首先,检查所有的数据库,看看哪个数据库的dbo用户所对应的登录名为空。
其次,找到这个出问题的数据库之后,执行一些语句将这个数据库的所有者更改为某个在目前服务器上存在的登录名称,即

1
2
3
4
USE DBName
GO
EXEC sp_changedbowner 'sa'
GO

将每个出问题的数据库都按照上面的方法检查并更改之后,就可以顺利地修改sa密码了。

, , ,

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注