知识大全 讲解孤立用户和对象名无效问题的解决方法[1]

Posted 数据库

篇首语:一身转战三千里,一剑曾当百万师。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 讲解孤立用户和对象名无效问题的解决方法[1]相关的知识,希望对你有一定的参考价值。

  在使用数据库的过程中 经常会遇到数据库迁移或者数据迁移的问题 或者有突然的数据库损坏 这时需要从数据库的备份中直接恢复 但是 此时会出现问题 这里说明几种常见问题的解决方法

  一 孤立用户的问题

  比如 以前的数据库的很多表是用户test建立的 但是当我们恢复数据库后 test用户此时就成了孤立用户 没有与之对应的登陆用户名 哪怕你建立了一个test登录用户名 而且是以前的用户密码 用该用户登录后同样没办法操作以前属于test的用户表

  这个问题有两种办法解决

  先说解决的前提条件

  首先 要用备份文件还原数据库 我们这里的数据库名为testdb 里面有属于用户test的用户表 这个很容易了操作了 不多讲了 在企业管理器中很方便可以恢复 恢复后 就产生了孤立用户test

  然后 用sa用户或者具有DBA权限的用户登录 创建一个test数据库登录用户 密码随便设置了 也可以和以前的保持一致 我们用它来对应孤立的test用户

  下面就有两种操作方法了 第一种就是改变对象的属主 第二种就是使登录用户和数据库的孤立用户对应起来

  方法一 修改对象属主

  就是将原本属于数据库用户test的用户表 修改为属于dbo的用户表 然后修改test登录用户的数据库为testdb 就可以直接使用test登录用户登录后对该数据库进行操作了

  使用的存储过程

  sp_changeobjectowner [ @objname = ] object [ @newowner = ] owner

  参数说明

  [ @objname = ] object

  当前数据库中现有表 视图 用户定义函数或存储过程的名称 object 是 nvarchar( ) 没有默认值 如果架构及其所有者具有相同的名称 则 object 可由现有对象所有者限定 格式为 existing_owner object

  [ @newowner=] owner

  将成为对象的新所有者的安全帐户的名称 owner 的数据类型为 sysname 没有默认值 owner 必须是可访问当前数据库的有效数据库用户 服务器角色 Microsoft Windows 登录名或 Windows 组 如果新所有者是没有对应数据库级主体的 Windows 用户或Windows 组 则将创建数据库用户

  实例

  以下示例将 authors 表的所有者更改为dbo

  EXEC sp_changeobjectowner authors dbo ;  GO

  这个方法有个最大的缺点就是 当表的数量非常多 而且还有存储过程或者触发器之类的修改起来会非常麻烦 需要一个一个修改 所以 不提倡使用 现在网上有一个批量修改的存储过程 大家可以找一下 这里就不说了 而是教大家一个更简单的

cha138/Article/program/SQL/201311/16308

相关参考

知识大全 如何解决不能一次创建多表的问题

  一次操作创建多个对象一个不成功则全部不成功    第一步创建用户      createuseraa      identifiedbyaa      defaulttablespaceusers

知识大全 轻松解决asp.net用户ASPNET登录失败的问题

轻松解决asp.net用户ASPNET登录失败的问题  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

知识大全 Java SynDemo对象如何解决继承问题

JavaSynDemo对象如何解决继承问题  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  Jav

知识大全 单亲家庭的孩子都有哪些心理问题怎么解决

单亲家庭的孩子都有哪些心理问题怎么解决问题会有很多,而且都不一样,个体差异和环境的不同进而导致天差地别心理问题。恋父恋母过度依赖、对父母冷淡孤立缺乏感情都可能会发生。但是万变不离其宗——缺爱,进而无安

分布式计算机控制系统的设计大体上分成哪几个阶段?各个阶段主要解决哪些问题?

  分布式计算机控制系统的设计大体上可分为三个阶段。  第—阶段是系统分析与方案论证阶段。这一阶段的主要工作是调查研究和分析用户对系统的需求,即系统应具有的功能与主要性能指标,针对被控对象的数学模型,

分布式计算机控制系统的设计大体上分成哪几个阶段?各个阶段主要解决哪些问题?

  分布式计算机控制系统的设计大体上可分为三个阶段。  第—阶段是系统分析与方案论证阶段。这一阶段的主要工作是调查研究和分析用户对系统的需求,即系统应具有的功能与主要性能指标,针对被控对象的数学模型,

知识大全 重新编译PLSQL中无效对象或指定对象

重新编译PLSQL中无效对象或指定对象  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!Oracle&

知识大全 PB中同时“继承”多个用户自定义数据窗口对象[1]

PB中同时“继承”多个用户自定义数据窗口对象[1]  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!&

知识大全 Asp.Mvc 2.0用户登录实例讲解:客户端验证

Asp.Mvc2.0用户登录实例讲解:客户端验证  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  

知识大全 Asp.Mvc 2.0用户登录实例讲解:服务器端验证

Asp.Mvc2.0用户登录实例讲解:服务器端验证  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!