Sql Server 대상 의 현재 소유 자 를 대상 소유자 로 변경

데이터베이스 작업 에서 데이터베이스 대상 목록 이 일반적인 요소 인 object name 만 있 는 것 이 아니 라 object owner.object name 을 사용 하여 대상 을 참조 할 것 입 니 다.그러나 현재 데이터베이스 에 있 는 대상 의 소유 자 를 변경 하려 면 시스템 저장 과정 을 사용 할 수 있 습 니 다. sp_changeobjectowner (여 기 를 클릭 하여 더 자세히)spchangeobject owner 는 현재 데이터베이스 에 있 는 대상 의 소유 자 를 변경 합 니 다.문법: sp_changeobjectowner  [ @objname = ] 'object' , [, @newowner = ] 'owner'. 매개 변수. [@objname =] 'object'.       그러나 데이터베이스 대상 이 너무 많 기 때문에 현재 데이터베이스 에 있 는 대상 의 소유 자 를 일괄 처리 하 기 를 원 합 니 다.그러면 Net 을 사용 해 보 세 요. Fetch 의 nf_ChangeObjectOwner 저장 프로 세 스 로 일괄 처 리 를 완성 합 니 다.구체 적 인 용법 은 다음 과 같다.먼저 다음 코드 를 사용 하여 저장 과정 을 만든다.  nf_ChangeObjectOwner  Sql 서버 대상 의 현재 소유자 가 대상 소유자 로 변 경 됨 문법:nfChangeObjectOwner [, @current_Owner = ] 'owner',[,@target_Owner =] 'owner',[ ,@modify_Type=] type

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   ――사용자 테이블 을 제외 한 데이터베이스 대상(보기,저장 과정)의 소유 자 를'사용자 이름'으로 변경 합 니 다.

좋은 웹페이지 즐겨찾기