某台SqlServer数据库执行订阅发布的时候,报错:
无法作为数据库主体执行,因为主体“dbo”不存在、无法模拟这种类型的主体,或您没有所需的权限。(源:MSSQLServer,错误号:15517)
这种报错的原因是数据库的登录名都没有映射到这个数据库的dbo用户上。在企业管理器的图形界面看,就是在实例的登录名的属性窗口-用户映射:
在数据库Parameter上没有和dbo映射,所以Parameter的订阅发布操作会报上述错误。
“主体”这些对象可以通过系统表sys.database_principals和sys.server_principals查询,包括登录名、用户名、角色这些信息,前者是查询当前数据库的对象,后者是查询整个实例的对象。