我的一亩三分地 我就喜欢!
13fen  设为主页
 收藏本站
 
当前位置: > 一亩三分地:首页 > 网络学院 > 网络编程 > net专区 > 小技巧:更改数据库所有者的对象
热门文章排行
热门文章排行 检查email地址格式的代码(01-11)
PHP操作文件问答(01-11)
PHP安装攻略:安装并配置PHP(10-23)
PHP的十个高级技巧 4(10-23)
关于APE的介绍、播放及制作(03-22)
精采文章排行
精采文章排行 ASP.NET与MySQL数据库简明图示入门教(11-16)
ASP.NET与MySQL数据库简明图示入门教(11-16)
ASP.NET 链接数据库基础(11-16)
webconfig的设置节点说明(11-16)
部署ASP.NET的三大技术(上)(11-16)
技术专题推荐
网管论坛交流
 

小技巧:更改数据库所有者的对象 

作者:佚名   来源:Linux 宝库   点击:   日期:2006-12-22


  --功能说明:成批更改数据库所有者的对象
  --作者:不详
  --用法:exec ChangeObjectOwner 'nmkspro','dbo'
  --即可将所有nmkspro所有者的对象改为dbo所有
  --运行成功后将提示:"注意: 更改对象名的任一部分都可能破坏脚本和存储过程。"
  CREATE PROCEDURE dbo.ChangeObjectOwner
  @OldOwner as NVARCHAR(128),--参数原所有者
  @NewOwner as NVARCHAR(128)--参数新所有者
  AS
  
  DECLARE @Name  as NVARCHAR(128)
  DECLARE @Owner as NVARCHAR(128)
  DECLARE @OwnerName as NVARCHAR(128)
  
  DECLARE curObject CURSOR FOR
  select 'Name'  = name,
   'Owner'  = user_name(uid)
  from sysobjects
  where user_name(uid)=@OldOwner
  order by name
  
  OPEN curObject
  FETCH NEXT FROM curObject INTO @Name, @Owner
  WHILE(@@FETCH_STATUS=0)
  BEGIN
  if @Owner=@OldOwner
  begin
   set @OwnerName = @OldOwner + '.' + rtrim(@Name)
   exec sp_changeobjectowner @OwnerName, @NewOwner
  end
  
  FETCH NEXT FROM curObject INTO @Name, @Owner
  END
  
  close curObject
  deallocate curObject
  GO





文章评论】 【收藏本文】 【推荐好友】 【打印本文】 【论坛讨论

   相关文章:
·给你的FileSystemObject对象加把锁 ·在 Web 页上使用条件数值格式
·连接数据库查询手册(不仅仅适用于asp) ·警惕"给你的FileSystemObject对象加把锁"
·用ASP做全文检索 ·如何把ASP编写成DLL

   文章评论:(条)
  
 请留名: 匿名评论   点击查看所有评论 网管论坛
 

  责任编辑:一分  声明:刊登此文章是为了传递更多信息,文章内容仅供参考,转载请注明出处。