当前位置: 首页 > 图文教程 > 数据库 > MSSQL > 更改数据库中表的所属用户的两个方法

MSSQL
全面接触SQL语法(1)
全面接触SQL语法(2)
全面接触SQL语法(3)
全面接触SQL语法(4)
全面接触SQL语法(5)
全面接触SQL语法(6)
全面接触SQL语法(7)
跟我学SQL:(一)数据查询
跟我学SQL:(二) SELECT语句选项
精通数据库系列之入门-技巧篇2
精通数据库系列之入门-技巧篇3
精通数据库系列之入门-技巧篇4
精通数据库系列之入门-技巧篇5
SQL Server 7.0 入门(六)
Microsoft SQLServer安装示例
操作数据:SQL基础
操作数据:中级SQL
动态SQL四种类型的语句格式
Sql表数据操作
数据库正规化和设计技巧(1)

MSSQL 中的 更改数据库中表的所属用户的两个方法


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 58 ::
收藏到网摘: n/a

--更改某个表
exec sp_changeobjectowner 'tablename','dbo'


--存储更改全部表
CREATE PROCEDURE dbo.User_ChangeObjectOwnerBatch
 @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
-- select @name,@NewOwner,@OldOwner

 FETCH NEXT FROM curObject INTO @Name, @Owner
END

close curObject
deallocate curObject

GO