Sql Server 대상 의 현재 소유 자 를 대상 소유자 로 변경
4411 단어 Sql서버 대상 의 현재 소유 자 를 대상 소유자 로 변경
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
사용 방법: Exec nf_ChangeObjectOwner 'dbo','당신 의 사용자 이름',0 ――모든 사용자 테이블 소유 자 를'사용자 이름'Usage(사용 방법)로 변경 합 니 다. Exec nf_ChangeObjectOwner 'dbo','당신 의 사용자 이름',1 ――사용자 테이블 을 제외 한 데이터베이스 대상(보기,저장 과정)의 소유 자 를'사용자 이름'으로 변경 합 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Sql Server 대상 의 현재 소유 자 를 대상 소유자 로 변경데이터베이스 작업 에서 데이터베이스 대상 목록 이 일반적인 요소 인 object name 만 있 는 것 이 아니 라 object owner.object name 을 사용 하여 대상 을 참조 할 것 입 니 다.그러나 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.