大佬教程收集整理的这篇文章主要介绍了将Sql Server对象的当前拥有者更改成目标拥有者,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
感兴趣的小伙伴,下面一起跟随编程之家 code.cc的小编两巴掌来看看吧!
数据库操作当中,当数据库对象列表不只有一个普通的元素——objectname时,你将要使用objectowner.objectname来引用对象,但如果需要更改当前数据库中对象的所有者可以使用系统存储过程 sp_changeobjectowner (点击这里更详细)代码如下:
if exists (SELEct * from sysobjects where id = object_id(N'[nf_ChangeObjectowner]') and OBjeCTPROPERTY(id, N'IsProcedure') = 1)
drop procedure nf_ChangeObjectowner
GO
Create PROCEDURE nf_ChangeObjectowner
@current_owner nvarchar(255),
@target_owner nvarchar(255), @modify_Type int
/***********************************************************************************************
nf_ChangeObjectowner
实现功能: 将sql Server对象的当前拥有者更改成目标拥有者
**** 使用本代码前请备份数据库!
**** 所带来的安全问题,与俺家的驴子无关!
**** 欢迎斧头劈我,劈死偶有奖!
调用方法: Exec nf_ChangeObjectowner @current_owner,@target_owner,@modify_Type
输入参数: @current_owner nvarchar(255) --对象的当前拥有者
@target_owner nvarchar(255) --对象的目标拥有者
@modify_Type int --0为默认,更改表的拥有者;1为视图和存储过程
输出参数: RETURN值 = -1 --操作对象为0,操作对象不存在
= -2 --操作失败,可能对象被锁定
= 0(默认值) --操作成功,打印更改对象数目@object_num
@object_num --sql 打印值,返回更改成功的对象数目
@Write by Net Fetch. @At 2005/09/12
@Email: cnNetFetch*Gmail.Com blog.ad0.cn
************************************************************************************************/
AS
DECLARE @str_Tbl_Name nvarchar(255),@object_num int,@current_owner_uid smallint
Set @object_num = 0
DECLARE @return_status int
Set @return_status = -1
Set @current_owner_uid = (SELEct uid From sysusers Where [Name] = @current_owner)
If Not (Len(@current_owner_uid)>0)
RETURN -1
If (@modify_Type = 1)
DECLARE ChangeObjectowner_cursor cursOR FOR SELEct [Name] From sysobjects Where (type='U' or type='V' or type='P') and userstat=0 and [Name]<>'nf_ChangeObjectowner' and status>-1 and uid = @current_owner_uid
Else
DECLARE ChangeObjectowner_cursor cursOR FOR SELEct [Name] From sysobjects Where (type='U' or type='V' or type='P') and userstat<>0 and [Name]<>'dtproperties' and uid = @current_owner_uid
OPEN ChangeObjectowner_cursor
BEGIN transaCTION Change_Objectowner
FETCH NEXT FROM ChangeObjectowner_cursor INTO @str_Tbl_Name
WHILE (@@FETCH_STATUS = 0)
BEGIN
Set @str_Tbl_Name = @current_owner + '.' + @str_Tbl_Name
Print @str_Tbl_Name
EXEC @return_status = sp_changeobjectowner @str_Tbl_Name, @target_owner
IF (@return_status <> 0)
BEGIN
ROLLBACK transaCTION Change_Objectowner
RETURN -2
END
Set @object_num = @object_num + 1
FETCH NEXT FROM ChangeObjectowner_cursor INTO @str_Tbl_Name
END
Print @object_num
COMMIT transaCTION Change_Objectowner
CLOSE ChangeObjectowner_cursor
DEALLOCATE ChangeObjectowner_cursor
Go
以上是大佬教程为你收集整理的将Sql Server对象的当前拥有者更改成目标拥有者全部内容,希望文章能够帮你解决将Sql Server对象的当前拥有者更改成目标拥有者所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。